1. 程式人生 > >JS 中面向物件的5種寫法

JS 中面向物件的5種寫法

//定義Circle類,擁有成員變數r,常量PI和計算面積的成員函式area() 

Java程式碼  收藏程式碼
  1. //第1種寫法  
  2. function Circle(r) {  
  3.       this.r = r;  
  4. }  
  5. Circle.PI = 3.14159;  
  6. Circle.prototype.area = function() {  
  7.   return Circle.PI * this.r * this.r;  
  8. }  
  9. var c = new Circle(1.0);     
  10. alert(c.area());   

Java程式碼  收藏程式碼
  1. //第2種寫法  
  2. var Circle = function() {  
  3.    var obj = new Object();  
  4.    obj.PI = 3.14159;  
  5.    obj.area = function( r ) {  
  6.        return this.PI * r * r;  
  7.    }  
  8.    return obj;  
  9. }  
  10. var c = new Circle();  
  11. alert( c.area( 1.0 ) );  

Java程式碼  收藏程式碼
  1. //第3種寫法  
  2. var Circle = new Object();  
  3. Circle.PI = 3.14159;  
  4. Circle.Area = function( r ) {  
  5.        return this.PI * r * r;  
  6. }  
  7. alert( Circle.Area( 1.0 ) );  

Java程式碼  收藏程式碼
  1. //第4種寫法  
  2. var Circle={  
  3.    "PI":3.14159,  
  4.  "area":function(r){  
  5.           return this.PI * r * r;  
  6.         }  
  7. };  
  8. alert( Circle.area(1.0) );  

Java程式碼  收藏程式碼
  1. //第5種寫法  
  2. var Circle = new Function("this.PI = 3.14159;this.area = function( r ) {return r*r*this.PI;}"
    );  
  3. alert( (new Circle()).area(1.0) );  


大家來討論一下這五種寫法,它們的優缺點,哪個比較規範,特別是最後兩種,經常見到。