ES6之let命令詳解

来源:http://www.cnblogs.com/yy-hh/archive/2016/08/19/5786913.html
-Advertisement-
Play Games

let與塊級作用域 在代碼中,使用var申明的變數在代碼塊外面能被識別,但是let命令卻不能被識別,這樣就實現了js的塊級作用域,我們在使用條件語句 迴圈語句等就會不擔心變數污染的問題了,以下是兩種寫法等對比: es6: es5: 在{}用let聲明的變數只有在{}內是有效的 let不會有變數提升 ...


let與塊級作用域 

{    
  var foo='foo'; let bar='bar'; } console.log(foo,'var'); //foo var
console.log(bar ,'bar');//Uncaught ReferenceError: bar is not defined

在代碼中,使用var申明的變數在代碼塊外面能被識別,但是let命令卻不能被識別,這樣就實現了js的塊級作用域,我們在使用條件語句 迴圈語句等就會不擔心變數污染的問題了,以下是兩種寫法等對比:

es6:

for (let i = 0; i < a.length; i++) {
    let x = a[i]
    …
}
for (let i = 0; i < b.length; i++) {
    let y = b[i]
    …
}

let callbacks = []
for (let i = 0; i <= 2; i++) {
    callbacks[i] = function () { return i * 2 }
}
callbacks[0]() === 0
callbacks[1]() === 2
callbacks[2]() === 4

es5:

var i, x, y;
for (i = 0; i < a.length; i++) {
    x = a[i];
    …
}
for (i = 0; i < b.length; i++) {
    y = b[i];
    …
}

var callbacks = [];
for (var i = 0; i <= 2; i++) {
    (function (i) {
        callbacks[i] = function() { return i * 2; };
    })(i);
}
callbacks[0]() === 0;
callbacks[1]() === 2;
callbacks[2]() === 4;

在{}用let聲明的變數只有在{}內是有效的   

let不會有變數提升

熟悉js開發的都知道函數有兩種聲明方式

 

a(); // 'a'
b(); // 報錯不是一個函數 其實是undefined
function a(){
   console.log('a');
}

var b=function(){
   console.log('b');
}

 

這兩種方式js解析順序是不一樣的, 首先函數a會被js載入然後執行  var b ;至於b是什麼數據會等第二批執行,也就是正常按照從上到下執行代碼,在執行b()的時候還是未初始化的狀態但是並沒有報錯因為var已經被優先執行了 這種就是變數提升,此時我們修改下代碼

  a();  // 'a'
  b(); // b is not defined
  function a(){
   console.log('a'); 
  }

  let b=function(){
   console.log('b');
  }

雖然仍是報錯但是明顯提示不存在b變數了,所以使用了let之後就不會優先執行了也會回歸“第二批”執行的隊伍中,function a(){} 依然是“第一批”優先執行的代碼。

 

變數綁定和不可重新定義

js是存在作用域鏈的,在特定作用域下只能獲取同級或者高層級的變數;但是let存在變數綁定行為,不遵循作用域鏈;

     let a=1; 
     (function (){
       a=2; //a is not defined
       let a;
       console.log(a);
     }());

    let a=1; 
      (function (){
        a=2; 
        console.log(a);  //2
    }());

我們可以這樣理解,在當前執行的作用域內如果沒有對變數定義 則會從高層級級獲取,如果已經存在則封閉當前作用域不再考慮高層級是否聲明瞭該變數;

在相同作用域內,let是不能重覆聲明同一個變數的;但是var則不在乎聲明多少次,永遠都是後者替換前者;

      var foo=123;
      var foo=456;
      console.log(foo);   //456

      let bar=123;
      let bar=456; //Identifier 'bar' has already been declared
      console.log(bar);

有了塊級作用域我們再也不用寫匿名函數來進行作用域封閉了,以前你可能是這樣寫:

(function () {
    var foo = function () { return 1; }
    foo() === 1;
    (function () {
        var foo = function () { return 2; }
        foo() === 2;
    })();
    foo() === 1;
})();

但是現在不用這樣麻煩了,你完全可以這樣寫: 

{
    function foo () { return 1 }
    foo() === 1
    {
        function foo () { return 2 }
        foo() === 2
    }
    foo() === 1
}

參考了了阮一峰的介紹 做了一些簡化和自己的例子 歡迎補充~

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 0.前提條件 環境兩台ubuntu版本14.04 64位系統(並獲取root許可權) 假設兩台伺服器ip為:172.16.34.214(master),172.16.34.215(backup),keepalived的虛擬ip為172.16.34.216 兩台ubuntu系統上裝好docker,版本如 ...
  • 1、框模型:盒模型,①對象實際寬度=左右外邊距+左右邊框+左右內邊距 + width;②對象實際高度=上下外邊距+上下邊框+上下內邊距 + height; 2、外邊距:margin:取值:①top(上) right(右) bottom(下) left(左);②value:一個值,四個方向相同;③to ...
  • 輪播圖在以後的應用中還是比較常見的,不需要多少行代碼就能實現。但是在只掌握了js基礎知識的情況下,怎麼來用較少的而且邏輯又簡單的方法來實現呢?下麵來分析下幾種不同的做法: 1、利用位移的方法來實現 首先,我們可以在body中添加一個div並且將寬度設置成百分比(自適應頁面),比例具體是相對誰的百分比 ...
  • [1]創建節點 [2]插入節點 [3]移除節點 [4]替換節點 [5]複製節點 ...
  • 一直對移動項目不是很熟悉,做的很少,用的都是一些百分比,惡補了一下。 一.首先看下頭部。 format-detection翻譯成中文的意思是“格式檢測”,顧名思義,它是用來檢測html里的一些格式的,那關於meta的format-detection屬性主要是有以下幾個設置:meta name="fo ...
  • 前言 隨著移動設備的普及,移動web在前端工程師們的工作中占有越來越重要的位置。移動設備更新速度頻繁,手機廠商繁多,導致的問題是每一臺機器的屏幕寬度和解析度不一樣。這給我們在編寫前端界面時增加了困難,適配問題在當下顯得越來越突出。記得剛剛開始開發移動端產品的時候向設計MM要了不同屏幕的設計圖,結果可 ...
  • 話說App一般都帶有分享到社交平臺的入口,web網頁的分享也有很不錯的框架,但是隨著HTML5的不斷發展,手機web頁面越來越多的進入到我們的生活中,那如何在我們的手機上完成分享呢?話說各大分享平臺都有針對Android、Ios的SDK,作為開發者,我們只需要將SDK集成的我們的項目中即可,通過提供 ...
  • 標簽頁的切換方式 1、控制tab的顯示與隱藏 2、tab不切換,數據載入 控制tab的顯示與隱藏 前端腳本: 1、jquery實現: 引入jquery文件,代碼簡潔 jquery文件較大,瀏覽器不相容 2、js 實現 無需引入jquery文件代碼量大,需每個標簽添加函數及ID 3、插件實現 無需引入 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...