摘要:談談也是一種選擇歷史故事在之前是一門被稱為沒有塊級作用域的語言看看代碼輸出結果權威解析這是因為被聲明在當前函數(shù)的作用域內不管你聲明在函數(shù)的什么位置在函數(shù)執(zhí)行之前解析器會掃描當前函數(shù)作用域并將以和開頭的語句的變量名添加到當前函數(shù)作用域內這意味
談談 var, let, const. var 也是一種選擇 歷史故事
在 ES6 之前, JavaScript 是一門被稱為沒有塊級作用域的語言.
看看代碼:
(function(){ "use strict"; console.log(i) for (var i = 0; i < 10; ++i) { console.log(i) } console.log("i=" + i) })()
輸出結果:
undefined
...
...
i=10
權威解析: i=10 這是因為 i 被聲明在當前函數(shù)的作用域內, var 不管你聲明在函數(shù)的什么位置, 在函數(shù)執(zhí)行之前, 解析器會掃描當前函數(shù)作用域, 并將以 var 和 function 開頭的語句的變量名添加到當前函數(shù)作用域內, 這意味著諸如 var func = function name() {} 這樣的語句的右邊的函數(shù)的名字是不會被添加到當前作用域內的( 但是在函數(shù)內部可以訪問 ), 在 ES6 中的 class 也有同樣的表現(xiàn). 此時 var 聲明的變量還沒有值( undefined ), 這也是第一個輸出語句為什么沒報錯而輸出 undefined 的原因; function 聲明的函數(shù)名會指向一個函數(shù)對象( 也就是 __proto__ 屬性指向 Function.prototype ).
這種現(xiàn)象對于習慣了塊級作用域的程序猿來說是災難般的. 于是搞標準的那幫人弄了 let, const 這樣的關鍵字出來. let 和 const 聲明的變量不會在之前說的掃描階段里被添加到當前作用域內, 并且會在當前大括號內的作用域塊結束的時候被清理掉, 也就是說 ES6 有了塊級作用域. 對于 const 還加了兩條限制.
如果 const 的變量是基本類型( null, undefined, string, number ), 那么變量的值不能變.
如果 const 的變量是引用類型( object ), 那么其引用值不能改變.
看代碼就知道了
(function(){ "use strict"; // 如果執(zhí)行下面這行代碼, 會報引用錯誤 // console.log(i) // Reference Error // 如果執(zhí)行下面這行代碼, 會報引用錯誤 // 因為 i 在 for 循環(huán)結束后就被銷毀了 setTimeout(() => console.log(i), 0) for (let i = 0; i < 10; ++i) { console.log(i) } const foo = 10 const bar = {} foo = 11 // TypeError bar.type = "const" // OK })()我該怎么選擇?
如果你稍微接觸過 ES6, 別人會告訴你 絕對不要用 var, 如果變量在將來不會改變就用 const, 否則就用 let.
這句話我是贊同的, 但是在我寫代碼的時候遇到某些情況不得不用 var, 看代碼:
async function clearExpiredRss() { try { var connection = await pool.getConnection() connection.query(`DELETE FROM ${TABLE_NAME} WHERE date+3600*1000 < ${Date.now()}`) } catch (e) { logger.error(e) } finally { connection && connection.release() } }
connection 變量如果用 let 或 const 聲明的話, finally 內就沒辦法釋放連接了. 有人說為什么不直接在 try 內寫個 if 判斷? 個人覺得在 finally 里看起來更優(yōu)雅一些.
所以說, 有時候作用域鏈反倒是 javascript 這門語言的優(yōu)勢, 為此, 我不得不說, javascript 是世界上最好的語言!
最后想說的你們有沒有遇到過 github issues 上寫文章的人... 我反正是看到了很多在 Github 上的 issues 寫技術博客的人. 之前都喜歡用 Github 的 Subscribe 功能來訂閱, 或者直接 Watching ... 這兩天突發(fā)奇想, 能不能把 issues 轉換成 RSS 呢? 所以就擼了一個小工具, github-issues-rss, 求關注, 求 star !
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/87054.html
摘要:另外這樣的異常捕獲不能捕獲的異常錯誤信息,這點需要注意。最終大致的流程圖如下結語前端異常捕獲與上報是前端異常監(jiān)控的前提,了解并做好了異常數(shù)據(jù)的收集和分析才能實現(xiàn)一個完善的錯誤響應和處理機制,最終達成數(shù)據(jù)可視化。 關于 微信公眾號:前端呼啦圈(Love-FED) 我的博客:勞卜的博客 知乎專欄:前端呼啦圈 前言 Hello,大家好,又與大家見面了,這次給大家分享下前端異常監(jiān)控中需...
摘要:那么,它到底是如何工作的呢讓我們從一種更簡單的實現(xiàn)開始實際上這種實現(xiàn)代碼更短,并且更易讀是函數(shù)原型中的一個函數(shù),它調用函數(shù),使用第一個參數(shù)作為參數(shù),并傳遞剩余參數(shù)作為被調用函數(shù)的參數(shù)。 原文:The Most Clever Line of JavaScript 作者:Seva Zaikov 原文 最近 一個朋友 發(fā)給我一段非常有趣的 JavaScript 代碼,是他在某個 開源庫中...
嚴格模式 首先來了解一下嚴格模式是什么?嚴格模式是JavaScript中的一種限制性更強的變種方式,不是一個子集:它在語義上與正常代碼有明顯的差異,不支持嚴格模式的瀏覽器與支持嚴格模式的瀏覽器行為上也不一樣,所以不要在未經嚴格模式特性測試情況下使用嚴格模式,嚴格模式可以與非嚴格模式共存,所以腳本可以逐漸的選擇性加入嚴格模式 嚴格模式的目的 首先,嚴格模式會將JavaScript陷阱直接變成明顯的錯...
閱讀 6932·2021-09-22 15:08
閱讀 1933·2021-08-24 10:03
閱讀 2446·2021-08-20 09:36
閱讀 1323·2020-12-03 17:22
閱讀 2481·2019-08-30 15:55
閱讀 913·2019-08-29 16:13
閱讀 3061·2019-08-29 12:41
閱讀 3257·2019-08-26 12:12