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) );
大家来讨论一下这五种写法,它们的优缺点,哪个比较规范,特别是最后两种,经常见到。
//定义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) );
大家来讨论一下这五种写法,它们的优缺点,哪个比较规范,特别是最后两种,经常见到。
相关文章推荐
- js 面向对象5种写法
- JS 中面向对象的5种写法
- JS 中面向对象的5种写法
- JS 中面向对象的5种写法
- JS 中面向对象的5种写法和拓展JS对象的写法
- JS 中面向对象的5种写法
- JS 中面向对象的5种写法
- JS 中面向对象的5种写法
- JS 中面向对象的5种写法
- JS 中面向对象的5种写法
- js中面向对象的5种写法
- 【转】JS 中面向对象的5种写法
- JS面向对象的写法 -- 此景最美
- JS面向对象的标准写法
- js中面向对象的5钟写法(转)
- js 面向对象学习6 几种面向对象写法的对比
- 归纳下js面向对象的几种常见写法
- js--面向对象--js类的5中写法
- JS 中面向对象写法
- javascript面向对象的5种写法