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

es6函數(shù)中的作用域?qū)嵗治?/h1>
 更新時間:2020年04月18日 10:39:36   作者:wangliang_001  
這篇文章主要介紹了es6函數(shù)中的作用域,結(jié)合實例形式分析了es6函數(shù)作用域相關(guān)原理、用法與操作注意事項,需要的朋友可以參考下

本文實例講述了es6函數(shù)中的作用域。分享給大家供大家參考,具體如下:

一旦設(shè)置了參數(shù)的默認值,函數(shù)進行聲明初始化時,參數(shù)會形成一個單獨的作用域(context)。等到初始化結(jié)束,這個作用域就會消失。這種語法行為,在不設(shè)置參數(shù)默認值,是不會出現(xiàn)的。

var x = 1;

function f(x, y = x) {
 console.log(y);
}

f(2) // 2

上面的代碼中,參數(shù)y的默認值等于變量x。調(diào)用函數(shù)f時,參數(shù)形成一個單獨的作用域。在這個作用域里面,默認值變量x指向第一個參數(shù)x,而不是全局變量x,所以輸出是2。

再看下面的例子。

let x = 1;

function f(y = x) {
 let x = 2; 
 console.log(y)
}

上面代碼中,函數(shù)f調(diào)用時,參數(shù)y = x形成一個單獨的作用域,這個作用域里面,變量x本身沒有定義,所以指向外層的全局變量x。函數(shù)調(diào)用時,函數(shù)體內(nèi)部的局部變量x影響不到默認值變量x。

如果此時,全局變量x不存在,就會報錯。

function f(y = x) {
 let x = 2;
 console.log(y)
}

f() // ReferenceError: x is not defined

下面這樣寫,也會報錯。

var x = 1;

function foo(x = x) {
 // ...
}

foo() // ReferenceError: x is not defined

上面代碼中,參數(shù)x = x形成一個單獨作用域,實際執(zhí)行的是 let x = x,由于暫時性死區(qū)的原因,這行代碼會報錯"x未定義"。

如果參數(shù)的默認值是一個函數(shù),該函數(shù)的作用域也遵守這個規(guī)則。請看下面的例子。

let foo = 'outer'

function bar(func = () => foo) {
 let foo = 'inner';
 console.log(func())
}

bar() // outer

上面代碼中,函數(shù)bar的參數(shù)func的默認值是一個匿名函數(shù),返回值是變量foo。函數(shù)參數(shù)形成的單獨的作用域里面,并沒有定義變量foo,所以foo指向外層的全局變量foo,因此輸出outer。

如果寫成下面這樣,就會報錯。

function bar (func = () => foo) {
 let foo = 'inner'
 console.log(func())
}

bar() // ReferenceError: foo is not defined

上面代碼中,匿名函數(shù)里面的foo指向函數(shù)外層,但是函數(shù)外層并沒有聲明變量foo,所以報錯了。

下面是一個更復雜的例子。

var x = 1;
function foo(x, y = function() {x = 2;}) {
 var x = 3;
 y()
 console.log(x)
}

foo() // 3
x // 1

上面代碼中,函數(shù)foo的參數(shù)形成一個單獨作用域。這個作用域里面,首先聲明了變量x,然后聲明了變量y,y的默認值是一個匿名函數(shù)。這個匿名函數(shù)內(nèi)部的變量x, 指向同一個作用域的第一個參數(shù)x。函數(shù)foo內(nèi)部又聲明了一個內(nèi)部變量。該變量與第一個參數(shù)x由于不是同一個作用域,所以不是同一個變量,因此執(zhí)行y后,內(nèi)部變量x和外部全局變量x的值都沒變。

如果將var x = 3的var 去除,函數(shù)foo的內(nèi)部變量x就指向第一個參數(shù),與匿名函數(shù)內(nèi)部的x是一致的,所以最后輸出的就是2,而外層的全局變量x依然不受影響。

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具http://tools.jb51.net/code/HtmlJsRun測試上述代碼運行效果。

更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《JavaScript常用函數(shù)技巧匯總》、《javascript面向?qū)ο笕腴T教程》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》及《JavaScript數(shù)學運算用法總結(jié)

希望本文所述對大家JavaScript程序設(shè)計有所幫助。

相關(guān)文章

最新評論