js中面向对象的5种写法


今天为了看看别人网站上是如何实现类似于横向tab选项卡切换效果是如何实现的,其实这个是根据具体的业务而定,可以同过不同的方法而定,注意我这里说的是类似。看了一些大型网站是如何实现的,就看了看别人写的js代码,看着越来越不明白,写的有写代码,看着好像有点像java中面向对象编程,并不是以前没见过,只是以前更不没有仔细研究,只是往里面添加了一些数据而已,今天仔细研究,结果让我涨知识了,妈的js居然有面向对象的写法(感觉像是发现了新大陆,好兴奋,朋友们莫笑话,有写朋友可能会骂,这个sb,居然连这个都不知道。说句老师话我真不知道)。 发现这个我就上网上搜了一些资料,准备学习学习。


一、先从面向对象的写法学起。

下面这篇文章是从一个论坛上抄写来的,论坛的主题是讨论这五种写法,它们的优缺点,哪个比较规范,特别是最后两种,经常见到。

文章转自:http://www.iteye.com/topic/434462

//定义Circle类,拥有成员变量r,常量PI和计算面积的成员函数area() 

Java代码   收藏代码
  1. //第1种写法  
  2. function Circle(r) {  
  3.       this.r = r;  
  4. }  
  5. Circle.PI = 3.14159;  
  6. Circle.prototype.area = function() {  
  7.   return Circle.PI * this.r * this.r;  
  8. }  
  9.   
  10. var c = new Circle(1.0);     
  11. alert(c.area());   

Java代码   收藏代码
  1. //第2种写法  
  2. var Circle = function() {  
  3.    var obj = new Object();  
  4.    obj.PI = 3.14159;  
  5.      
  6.    obj.area = function( r ) {  
  7.        return this.PI * r * r;  
  8.    }  
  9.    return obj;  
  10. }  
  11.   
  12. var c = new Circle();  
  13. alert( c.area( 1.0 ) );  

Java代码   收藏代码
  1. //第3种写法  
  2. var Circle = new Object();  
  3. Circle.PI = 3.14159;  
  4. Circle.Area = function( r ) {  
  5.        return this.PI * r * r;  
  6. }  
  7.   
  8. alert( Circle.Area( 1.0 ) );  

Java代码   收藏代码
  1. //第4种写法  
  2. var Circle={  
  3.    "PI":3.14159,  
  4.  "area":function(r){  
  5.           return this.PI * r * r;  
  6.         }  
  7. };  
  8. alert( Circle.area(1.0) );  

Java代码   收藏代码
  1. //第5种写法  
  2. var Circle = new Function("this.PI = 3.14159;this.area = function( r ) {return r*r*this.PI;}");  
  3.   
  4. alert( (new Circle()).area(1.0) );  

(需要注意的是:第五种方法new的是Function 而不是function; 在JavaScript 方法、变量是区分大小写的)
大家来讨论一下这五种写法,它们的优缺点,哪个比较规范,特别是最后两种,经常见到。

有兴趣的朋友可以看看这个帖子,通过大家讨论,比较认同的是第一种写法和第四种写法,所以以后学习就按照这两种写法就好,其它的了解就好,能看懂别人写的代码就可以。


你可能感兴趣的:(js)