鍍金池/ 問(wèn)答/數(shù)據(jù)庫(kù)  HTML/ 構(gòu)造函數(shù)Function()參數(shù)傳入帶引號(hào)參數(shù)和傳入不帶引號(hào)參數(shù)對(duì)局部變量對(duì)外部

構(gòu)造函數(shù)Function()參數(shù)傳入帶引號(hào)參數(shù)和傳入不帶引號(hào)參數(shù)對(duì)局部變量對(duì)外部變量是怎么操作的?

(function(){
        var call = '23';
       Function(console.log(call))(); //23
    })();

打印的是23

(function(){
        var call = '23';
       Function('console.log(call)')(); //未定義
    })();

不明白為什么一個(gè)傳入不帶引號(hào)參數(shù)和帶引號(hào)參數(shù)結(jié)果為什么不一樣?

回答
編輯回答
心沉

這么講吧,首先明確一個(gè)東西,

(function(){ 
    //code
})();

這個(gè)是用來(lái)創(chuàng)建閉包的,這個(gè)不管。
然后直接看里面的。

Function是javascript所有函數(shù)的原型,可以通過(guò)
Function(args)的方法來(lái)創(chuàng)建一個(gè)函數(shù)。

在第一個(gè)例子里面,傳遞給Function函數(shù)的是console.log(call)
在閉包里面,call = "23",console.log會(huì)被立即執(zhí)行,所以實(shí)際上執(zhí)行的結(jié)果是
Function(undefined)(),

第二個(gè)例子的話,要先去看MDN,MDN上明確指出
clipboard.png
閉包之內(nèi)的變量不會(huì)被引用,因此這里雖然成功創(chuàng)建了一個(gè)函數(shù)

? anonymous() {
console.log(call)
}

但是其并不具備call的作用域,在立即執(zhí)行的時(shí)候會(huì)報(bào)call is undefined錯(cuò)誤。

這個(gè)問(wèn)題主要是關(guān)于Function的這一個(gè)特點(diǎn)

2018年1月31日 01:57