您好,登錄后才能下訂單哦!
這篇文章給大家介紹怎么在es6函數中使用嚴格模式,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
從es5開始,函數內部可以設定為嚴格模式。
function doSomething(a, b) { 'use strict' // code }
es2016做了一點修改,規定只要函數參數使用了默認值,解構賦值,或者擴展運算符,那么函數內部就不能顯示設定為嚴格模式,否則會報錯。
// 報錯 function doSomething(a, b = a) { 'use strict' // code } const doSomething = function({a, b}) { 'use strict' // code } const doSomething = (...a) => { 'use strict' // code } const obj = { doSomething({a, b}) { 'use strict' // code } }
這樣規定的原因是,函數內部的嚴格模式,同時適用于函數體和函數參數。但是,函數執行的時候,先執行函數參數,然后再執行函數體,這樣就有一個不合理的地方,只有從函數體之中,才能知道參數是否應該以嚴格模式執行,但是參數卻應該先于函數體執行。
function doSomething(value = 070) { 'use strict' return value }
上面代碼中,參數value的默認值是八進制數070,但是嚴格模式下不能用前綴0表示八進制,所以應該報錯,但是實際上,javascript引擎會先成功執行value = 070 ,然后進入函數內部,發現需要用嚴格模式執行,這時才會報錯。
雖然可以先解析函數體代碼,再執行參數代碼,但是這樣無疑就增加了復雜性。因此,標準索性禁止了這種用法,只要參數使用了默認值,解構賦值,或者擴展運算符,就不能顯示指定嚴格模式。
兩種方法可以規避這種限制。第一種是設定全局性的嚴格模式,這是合法的。
'use strict' function doSomething(a, b = a) { // code }
第二種是把函數包在一個無參數的立即執行函數里面。
const doSomething = (function() { 'use strict' return function (value = 42) { return value } })
關于怎么在es6函數中使用嚴格模式就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。