建站学 - 轻松建站从此开始!

建站学-个人建站指南,网页制作,网站设计,网站制作教程

JavaScript常用的2种定义类的方式

时间:2008-11-15 19:09来源:网络 作者: 点击:
1. 混合构造函数/原型方式          function Car(sColor, iDoors, iMpg) {   this .color = sColor;   this .doors = iDoors;   this .mpg = iMpg;   this .drivers = new Array(“Mike”, “Sue”);  
1. 混合构造函数/原型方式

         function Car(sColor, iDoors, iMpg) {
  this .color = sColor;

  this .doors = iDoors;

  this .mpg = iMpg;

  this .drivers = new Array(“Mike”, “Sue”);

  }

  Car.prototype.showColor = function () {

  alert( this .color);

  };

  var oCar1 = new Car(“red”, 4 , 23 );

  var oCar2 = new Car(“blue”, 3 , 25 );

  oCar1.drivers.push(“Matt”);

  alert(oCar1.drivers); // outputs “Mike,Sue,Matt”

  alert(oCar2.drivers); // outputs “Mike,Sue”
 
  优点:具有其它方式的优点而没有其它方式的缺点

  不足:封装性欠缺

  2 . 动态原型方式

        function Car(sColor, iDoors, iMpg) {
  this .color = sColor;

  this .doors = iDoors;

  this .mpg = iMpg;

  this .drivers = new Array(“Mike”, “Sue”);

  if ( typeof Car._initialized == “undefined”) {

  Car.prototype.showColor = function () {

  alert( this .color);

  } ;

  Car._initialized = true ;

  }

  }
 
   优点:封装性比上一个方式更好

  总之,以上2种方式是目前最广泛使用的,尽量使用它们避免不必要的问题。

(责任编辑:admin)
织梦二维码生成器
顶一下
(1)
100%
踩一下
(0)
0%
------分隔线----------------------------
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 验证码:点击我更换图片