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è)計有所幫助。
您可能感興趣的文章:- ES6中箭頭函數(shù)的定義與調(diào)用方式詳解
- javascript ES6中箭頭函數(shù)注意細節(jié)小結(jié)
- ES6中的箭頭函數(shù)實例詳解
- 關(guān)于ES6箭頭函數(shù)中的this問題
- 詳解Javascript ES6中的箭頭函數(shù)(Arrow Functions)
- 深入淺出ES6新特性之函數(shù)默認參數(shù)和箭頭函數(shù)
- JavaScript ES6箭頭函數(shù)使用指南
- es6函數(shù)之尾調(diào)用優(yōu)化實例分析
- es6函數(shù)之尾遞歸用法實例分析
- es6函數(shù)name屬性功能與用法實例分析
- es6函數(shù)之箭頭函數(shù)用法實例詳解
相關(guān)文章
-
javascript獲取wx.config內(nèi)部字段解決微信分享
這篇文章主要介紹了javascript獲取wx.config內(nèi)部字段解決微信分享,需要的朋友可以參考下 2016-03-03
-
echarts報錯Cannot?read?properties?of?null?(reading?‘getA
最近在開發(fā)Echarts忽然遇到了個問題,這篇文章主要給大家介紹了關(guān)于echarts報錯Cannot?read?properties?of?null?(reading?‘getAttribute‘)的解決方法,需要的朋友可以參考下 2023-01-01
-
如何使Chrome控制臺支持多行js模式——意外發(fā)現(xiàn)
一直以來,Chrome控制臺都缺少象IE調(diào)試臺那樣的多行執(zhí)行模式,今天意外發(fā)現(xiàn)Chrome其實也支持多行模式 2013-06-06
-
javascript實現(xiàn)生成并下載txt文件方式
這篇文章主要介紹了javascript實現(xiàn)生成并下載txt文件方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教 2022-09-09
最新評論
本文實例講述了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è)計有所幫助。
- ES6中箭頭函數(shù)的定義與調(diào)用方式詳解
- javascript ES6中箭頭函數(shù)注意細節(jié)小結(jié)
- ES6中的箭頭函數(shù)實例詳解
- 關(guān)于ES6箭頭函數(shù)中的this問題
- 詳解Javascript ES6中的箭頭函數(shù)(Arrow Functions)
- 深入淺出ES6新特性之函數(shù)默認參數(shù)和箭頭函數(shù)
- JavaScript ES6箭頭函數(shù)使用指南
- es6函數(shù)之尾調(diào)用優(yōu)化實例分析
- es6函數(shù)之尾遞歸用法實例分析
- es6函數(shù)name屬性功能與用法實例分析
- es6函數(shù)之箭頭函數(shù)用法實例詳解
相關(guān)文章
javascript獲取wx.config內(nèi)部字段解決微信分享
這篇文章主要介紹了javascript獲取wx.config內(nèi)部字段解決微信分享,需要的朋友可以參考下2016-03-03echarts報錯Cannot?read?properties?of?null?(reading?‘getA
最近在開發(fā)Echarts忽然遇到了個問題,這篇文章主要給大家介紹了關(guān)于echarts報錯Cannot?read?properties?of?null?(reading?‘getAttribute‘)的解決方法,需要的朋友可以參考下2023-01-01如何使Chrome控制臺支持多行js模式——意外發(fā)現(xiàn)
一直以來,Chrome控制臺都缺少象IE調(diào)試臺那樣的多行執(zhí)行模式,今天意外發(fā)現(xiàn)Chrome其實也支持多行模式2013-06-06javascript實現(xiàn)生成并下載txt文件方式
這篇文章主要介紹了javascript實現(xiàn)生成并下載txt文件方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09