欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript中的new的使用方法與注意事項(xiàng)

 更新時(shí)間:2007年05月16日 00:00:00   作者:  
原文: JavaScript, We Hardly new Ya  --Douglas Crockford。    
http://yuiblog.com/blog/2006/11/13/javascript-we-hardly-new-ya/
引用
JavaScript是一門(mén)基于原型的語(yǔ)言,但它卻擁有一個(gè) new 操作符使得其看起來(lái)象一門(mén)經(jīng)典的面對(duì)對(duì)象語(yǔ)言。那樣也迷惑了程序員們,導(dǎo)致一些有問(wèn)題的編程模式。

其實(shí)你永遠(yuǎn)不需要在JavaScript使用 new Object()。用字面量的形式{}去取代吧。

同理,不要使用 new Array() ,而代之以字面量[]。JavaScript中的數(shù)組并不象Java中的數(shù)組那樣工作的,使用類似Java的語(yǔ)法只會(huì)讓你糊涂。

同理不用使用 new Number, new String, 或者 new Boolean。這些的用法只會(huì)產(chǎn)生無(wú)用的類型封裝對(duì)象。就直接使用簡(jiǎn)單的字面量吧。

不要使用 new Function 去創(chuàng)建函數(shù)對(duì)象。用函數(shù)表達(dá)式更好。比如:

frames[0].onfocus = new Function(”document.bgColor='antiquewhite'”)

更好的寫(xiě)法是:

frames[0].onfocus = function () {document.bgColor = ‘a(chǎn)ntiquewhite';};

第二種形式讓腳本編譯器更快的看到函數(shù)主體,于是其中的語(yǔ)法錯(cuò)誤也會(huì)更快被檢測(cè)出來(lái)。有時(shí)候程序員使用 new Function 是因?yàn)樗麄儧](méi)有理解內(nèi)部函數(shù)是如何工作的。

selObj.onchange = new Function(”dynamicOptionListObjects[”+
       dol.index+”].change(this)”);

如果我們讓用字符串做函數(shù)體,編譯器不能看到它們。如果我們用字符串表達(dá)式做函數(shù)體,我們同樣也看不到它們。更好的方式就是不要盲目編程。通過(guò)制造一個(gè)返回值為函數(shù)的函數(shù)調(diào)用,我們可以明確的按值傳遞我們想要綁定的值。這允許我們?cè)谘h(huán)中初始化一系列 selObj 對(duì)象。

selObj.onchange = function (i) {
   return function () {
       dynamicOptionListObjects[i].change(this);

   };
}(dol.index);

直接對(duì)一個(gè)函數(shù)使用new永遠(yuǎn)不是一個(gè)好主意。比如, new function 對(duì)構(gòu)造新對(duì)象沒(méi)有提供什么優(yōu)勢(shì)。

myObj = new function () {
   this.type = ‘core';
};

更好的方式是使用對(duì)象字面量,它更輕巧,更快捷。

myObj = {
   type: ‘core'
};

假如我們需要?jiǎng)?chuàng)建的對(duì)象包含的方法需要訪問(wèn)私有變量或者函數(shù),更好的方式仍然是避免使用new.

var foo = new function() {
   function processMessages(message) {
       alert(”Message: ” + message.content);
   }
   this.init = function() {
       subscribe(”/mytopic”, this, processMessages);
   }
}

通過(guò)使用 new 去調(diào)用函數(shù),對(duì)象會(huì)持有一個(gè)無(wú)意義的原型對(duì)象。這只會(huì)浪費(fèi)內(nèi)存而不會(huì)帶來(lái)任何好處。如果我們不使用new,我們就不用在對(duì)象鏈維護(hù)一個(gè)無(wú)用的prototype對(duì)象。所以我們可以用()來(lái)正確的調(diào)用工廠函數(shù)。

var foo = function () {
   function processMessages(message) {
       alert(”Message: ” + message.content);
   }
   return {
       init: function () {
           subscribe(”/mytopic”, this, processMessages);
       }
   };
}();

所以原則很簡(jiǎn)單: 唯一應(yīng)該要用到new操作符的地方就是調(diào)用一個(gè)古老的構(gòu)造器函數(shù)的時(shí)候。當(dāng)調(diào)用一個(gè)構(gòu)造器函數(shù)的時(shí)候,是強(qiáng)制要求使用new的。有時(shí)候可以來(lái)new一下, 有的時(shí)候還是不要了吧。
引用
注 原文:http://www.uiplanet.com/taobao/2007/05/15/%e4%bd%a0%e7%9c%9f%e7%9a%84%e4%bc%9a%e5%86%99javascript%e5%90%97%ef%bc%9f/
可以參考以下文章,英文的:http://msdn.microsoft.com/msdnmag/issues/07/05/JavaScript/default.aspx?loc=en#S6

相關(guān)文章

最新評(píng)論