您的位置:首页 > Web前端 > JavaScript

JS 中面向对象的5种写法

2014-11-13 10:29 190 查看
原文:http://www.iteye.com/topic/434462

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

Java代码


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

Java代码


//第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 ) );

Java代码


//第3种写法

var Circle = new Object();

Circle.PI = 3.14159;

Circle.Area = function( r ) {

return this.PI * r * r;

}

alert( Circle.Area( 1.0 ) );

Java代码


//第4种写法

var Circle={

"PI":3.14159,

"area":function(r){

return this.PI * r * r;

}

};

alert( Circle.area(1.0) );

Java代码


//第5种写法

var Circle = new Function("this.PI = 3.14159;this.area = function( r ) {return r*r*this.PI;}");

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

大家来讨论一下这五种写法,它们的优缺点,哪个比较规范,特别是最后两种,经常见到。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: