js中面向对象的写法

第一种:

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());   

第二种:

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 ) );  
第三种:

var Circle={   
   "PI":3.14159,   
 "area":function(r){   
          return this.PI * r * r;   
        }   
};   
alert( Circle.area(1.0) );  

第四种:

var Circle = new Object();   
Circle.PI = 3.14159;   
Circle.Area = function( r ) {   
       return this.PI * r * r;   
}   
  
alert( Circle.Area( 1.0 ) ); 


this的指向问题:

1、当this在事件处理函数中时,this是事件源(this对象时自动产生的);

2、this在某个对象的函数内部时,this表示该函数的所属对象;

3、当this所在的函数没有明确的对象时。this是window对象;

4、当this在构造函数内部时,this是new出来的对象


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值