JS 中面向物件的5種寫法
阿新 • • 發佈:2019-01-31
//定義Circle類,擁有成員變數r,常量PI和計算面積的成員函式area()
Java程式碼
Java程式碼
Java程式碼
Java程式碼
Java程式碼
大家來討論一下這五種寫法,它們的優缺點,哪個比較規範,特別是最後兩種,經常見到。
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) );
大家來討論一下這五種寫法,它們的優缺點,哪個比較規範,特別是最後兩種,經常見到。