WEB开发网      婵犻潧鍊婚弲顐︽偟椤栨稓闄勯柦妯侯槸閻庤霉濠婂骸浜剧紒杈ㄥ笚閹峰懘鎮╅崹顐ゆ殸婵炴垶鎸撮崑鎾趁归悩鐑橆棄闁搞劌瀛╃粋宥夘敃閿濆柊锕傛煙鐎涙ê鐏f繝濠冨灴閹啴宕熼鍡╀紘婵炲濮惧Λ鍕叏閳哄懎绀夋繛鎴濈-楠炪垽鎮归崶褍妲婚柛銊ュ缁傚秹鏁撻敓锟� ---闂佹寧娲╅幏锟�
开发学院网页设计JavaScript JavaScript常用的2种定义类的方式 阅读

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

 2008-11-14 20:02:14 来源:WEB开发网 闂侀潧妫撮幏锟�闂佸憡鍨电换鎰版儍椤掑倵鍋撳☉娆嶄沪缂傚稄鎷�婵犫拃鍛粶闁靛洤娲ㄩ埀顒佺⊕閵囩偟绱為敓锟�闂侀潧妫撮幏锟�  闂佺ǹ绻楀▍鏇㈠极閻愭娑樷枎閹邦剛娉氶梺鍛婎殔濞层劌鈻撻幋婵愬殫妞ゆ梻鍘х憴锟�
核心提示:1. 混合构造函数/原型方式 function Car(sColor, iDoors, iMpg) { this .color = sColor;this .doors = iDoors;this .mpg = iMpg;this .drivers = new Array(“Mike”, “Sue”);}Car.PRo

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种方式是目前最广泛使用的,尽量使用它们避免不必要的问题。

Tags:JavaScript 常用 定义

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接