论坛首页 Web前端技术论坛

JS 中面向对象的5种写法

浏览 74232 次
精华帖 (0) :: 良好帖 (3) :: 新手帖 (15) :: 隐藏帖 (0)
作者 正文
   发表时间:2009-07-28   最后修改:2009-08-10
//定义Circle类,拥有成员变量r,常量PI和计算面积的成员函数area()

//第1种写法
function Circle(r) {
      this.r = r;
}
Circle.PI = 3.14159;
Circle.prototype.area = function() {
  return Circle.PI * this.r * this.r;
}

var c = new Circle(1.0);   
alert(c.area()); 

//第2种写法
var Circle = function() {
   var obj = new Object();
   obj.PI = 3.14159;
   
   obj.area = function( r ) {
       return this.PI * r * r;
   }
   return obj;
}

var c = new Circle();
alert( c.area( 1.0 ) );

//第3种写法
var Circle = new Object();
Circle.PI = 3.14159;
Circle.Area = function( r ) {
       return this.PI * r * r;
}

alert( Circle.Area( 1.0 ) );

//第4种写法
var Circle={
   "PI":3.14159,
 "area":function(r){
          return this.PI * r * r;
        }
};
alert( Circle.area(1.0) );

//第5种写法
var Circle = new Function("this.PI = 3.14159;this.area = function( r ) {return r*r*this.PI;}");

alert( (new Circle()).area(1.0) );


大家来讨论一下这五种写法,它们的优缺点,哪个比较规范,特别是最后两种,经常见到。
   发表时间:2009-07-28  
我习惯第四种,因为第一次接触的就是这种。
0 请登录后投票
   发表时间:2009-07-29  
第四种,代码量少点。JSON在传递时更灵活。
0 请登录后投票
   发表时间:2009-07-29  
第四种在this的绑定上有些情况会有问题
0 请登录后投票
   发表时间:2009-07-29  
//定义Circle类,拥有成员变量r,常量PI和计算面积的成员函数area()

..后三种的类在哪里?我只看见对象啊...
0 请登录后投票
   发表时间:2009-08-01  
第一种, 个人觉得第一种的对像的封装看起来比较流畅.易读.
0 请登录后投票
   发表时间:2009-08-01  
马上要学习这个课程了,先来看看,谢谢
0 请登录后投票
   发表时间:2009-08-02  
wyh6635 写道
第一种, 个人觉得第一种的对像的封装看起来比较流畅.易读.

恩,我看到《JavaScript高级程序设计》里面也推荐第一种。
0 请登录后投票
   发表时间:2009-08-02  
ycysth 写道
马上要学习这个课程了,先来看看,谢谢


你还有课程啊?什么专业啊?我发现大学就是自学。
0 请登录后投票
   发表时间:2009-08-02  
看起json对象就会很舒服的感觉,对AJAX操作json对象很灵活用第四种吧
0 请登录后投票
论坛首页 Web前端技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics