詳解new function(){}和function(){}() 區(qū)別分析
更新時間:2008年03月22日 14:00:10 作者:
只要 new 表達(dá)式之后的 constructor 返回(return)一個引用對象(數(shù)組,對象,函數(shù)等),都將覆蓋new創(chuàng)建的匿名對象,如果返回(return)一個原始類型(無 return 時其實(shí)為 return 原始類型 undefined),那么就返回 new 創(chuàng)建的匿名對象。
情景一:
var yx01 = new function() {return "圓心"};
alert(yx01);
我們運(yùn)行情景一代碼,將返回顯示“[object object] ”,此時該代碼等價于:
function 匿名類(){
return "圓心";
}
var yx01 = new 匿名類();
alert(yx01);我們對情景一的代碼進(jìn)行下面改造:
var yx01 = new function() {return new String("圓心")};
alert(yx01);
我們運(yùn)行,將會發(fā)現(xiàn)返回的是“圓心”,這是為什么呢?
只要 new 表達(dá)式之后的 constructor 返回(return)一個引用對象(數(shù)組,對象,函數(shù)等),都將覆蓋new創(chuàng)建的匿名對象,如果返回(return)一個原始類型(無 return 時其實(shí)為 return 原始類型 undefined),那么就返回 new 創(chuàng)建的匿名對象
由于 new String 會構(gòu)造一個對象,而不是一個 string 直接量,且new String(x) 如果帶參數(shù),那么alert它的時候就會返回 x。所以 yx01 將返回 new String(”圓心”) 這個對象,而 alert yx01 則顯示 “圓心”。
情景二:
var yx02 = function() {return "圓心"}();
alert(yx02);我們運(yùn)行情景二代碼,將返回顯示“圓心”,此時該代碼等價于:
var 匿名函數(shù) = function() {return "圓心"};
yx02 = 匿名函數(shù)();
alert(yx02);很明顯,yx02 返回的是匿名函數(shù)的執(zhí)行結(jié)果值,即 yx02 為:“圓心”。
當(dāng)然匿名函數(shù)的執(zhí)行結(jié)果也可以為一個匿名對象。具體常見應(yīng)用可以看《Javascript的一種模塊模式》
var yx01 = new function() {return "圓心"};
alert(yx01);
我們運(yùn)行情景一代碼,將返回顯示“[object object] ”,此時該代碼等價于:
function 匿名類(){
return "圓心";
}
var yx01 = new 匿名類();
alert(yx01);我們對情景一的代碼進(jìn)行下面改造:
var yx01 = new function() {return new String("圓心")};
alert(yx01);
我們運(yùn)行,將會發(fā)現(xiàn)返回的是“圓心”,這是為什么呢?
只要 new 表達(dá)式之后的 constructor 返回(return)一個引用對象(數(shù)組,對象,函數(shù)等),都將覆蓋new創(chuàng)建的匿名對象,如果返回(return)一個原始類型(無 return 時其實(shí)為 return 原始類型 undefined),那么就返回 new 創(chuàng)建的匿名對象
由于 new String 會構(gòu)造一個對象,而不是一個 string 直接量,且new String(x) 如果帶參數(shù),那么alert它的時候就會返回 x。所以 yx01 將返回 new String(”圓心”) 這個對象,而 alert yx01 則顯示 “圓心”。
情景二:
var yx02 = function() {return "圓心"}();
alert(yx02);我們運(yùn)行情景二代碼,將返回顯示“圓心”,此時該代碼等價于:
var 匿名函數(shù) = function() {return "圓心"};
yx02 = 匿名函數(shù)();
alert(yx02);很明顯,yx02 返回的是匿名函數(shù)的執(zhí)行結(jié)果值,即 yx02 為:“圓心”。
當(dāng)然匿名函數(shù)的執(zhí)行結(jié)果也可以為一個匿名對象。具體常見應(yīng)用可以看《Javascript的一種模塊模式》
相關(guān)文章
JavaScript 常見對象類創(chuàng)建代碼與優(yōu)缺點(diǎn)分析
這幾種javascript類定義方式中,最常用的是雜合prototype/constructor 和 動態(tài)prototype方式。2009-12-12
javascript new一個對象的實(shí)質(zhì)
javascript 中,new一個對象的實(shí)質(zhì)是什么?即,當(dāng)我們構(gòu)建一個類的實(shí)例的時候,真正做了些什么?2010-01-01
學(xué)習(xí)JS面向?qū)ο蟪晒?借國慶發(fā)布個最新作品與大家交流
學(xué)習(xí)JS面向?qū)ο蟪晒?,借國慶發(fā)布個最新作品與大家交流,大家可以看下。2009-10-10
new fun的執(zhí)行過程分析,學(xué)習(xí)面向?qū)ο蟮呐笥芽梢詤⒖枷隆?/div> 2010-08-08
討論javascript(一)工廠方式 js面象對象的定義方法
看《javascript高級程序設(shè)計(jì)》有感2009-12-12
面向?qū)ο蟮腏avascript之二(接口實(shí)現(xiàn)介紹)
接口是面向?qū)ο驤avascript工具箱中最有用的特性之一。我們都知道GOF在設(shè)計(jì)模式中說到:面向接口編程,而非面向?qū)崿F(xiàn)編程2012-01-01
javascript 模式設(shè)計(jì)之工廠模式學(xué)習(xí)心得
接口的實(shí)現(xiàn),從而使不同子類可以被同等的對待,恰當(dāng)?shù)氖褂霉S模式,但不要拘泥與形式,理解本質(zhì)。2010-04-04最新評論

