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

js面向对象初步探究(上) js面向对象的5种写方法

2017-05-18 13:09 337 查看
非常长一段时间看网上大神的JS代码特别吃力。那种面向对象的写法方式让人看得云里来雾里去。于是就研究了一下JS面向对象。因为是初学,就将自己在网上找到的资料整理一下,作为记忆。

js面向对象的5种写方法:(来自http://www.iteye.com/topic/434462)

首先
定义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) );
在第一种方法中用到了pretotype请看下一节js中的pretotype
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: