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

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

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

打印的是23

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

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

回答
編輯回答
心沉

這么講吧,首先明確一個東西,

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

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

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

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

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

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

但是其并不具備call的作用域,在立即執(zhí)行的時候會報call is undefined錯誤。

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

2018年1月31日 01:57