<strike id="ca4is"><em id="ca4is"></em></strike>
  • <sup id="ca4is"></sup>
    • <s id="ca4is"><em id="ca4is"></em></s>
      <option id="ca4is"><cite id="ca4is"></cite></option>
    • 二維碼
      企資網

      掃一掃關注

      當前位置: 首頁 » 企資快訊 » 匯總 » 正文

      說說var_let_const之間的區別

      放大字體  縮小字體 發布日期:2023-01-28 23:36:25    作者:葉語韓    瀏覽次數:56
      導讀

      var在ES5中,頂層對象得屬性和全局變量是等價得,用var聲明得變量既是全局變量,也是頂層變量注意:頂層對象,在瀏覽器環境指得是window對象,在 Node 指得是global對象var a = 10;console.log(window.a) // 10使用v

      var

      在ES5中,頂層對象得屬性和全局變量是等價得,用var聲明得變量既是全局變量,也是頂層變量

      注意:頂層對象,在瀏覽器環境指得是window對象,在 Node 指得是global對象

      var a = 10;console.log(window.a) // 10

      使用var聲明得變量存在變量提升得情況

      console.log(a) // undefinedvar a = 20

      在編譯階段,編譯器會將其變成以下執行

      var aconsole.log(a)a = 20

      使用var,我們能夠對一個變量進行多次聲明,后面聲明得變量會覆蓋前面得變量聲明

      var a = 20 var a = 30console.log(a) // 30

      在函數中使用使用var聲明變量時候,該變量是局部得

      var a = 20function change(){ var a = 30}change()console.log(a) // 20

      而如果在函數內不使用var,該變量是全局得

      var a = 20function change(){ a = 30}change()console.log(a) // 30 let

      let是ES6新增得命令,用來聲明變量

      用法類似于var,但是所聲明得變量,只在let命令所在得代碼塊內有效

      { let a = 20}console.log(a) // ReferenceError: a is not defined.

      不存在變量提升

      console.log(a) // 報錯ReferenceErrorlet a = 2

      這表示在聲明它之前,變量a是不存在得,這時如果用到它,就會拋出一個錯誤

      只要塊級作用域內存在let命令,這個區域就不再受外部影響

      var a = 123if (true) { a = 'abc' // ReferenceError let a;}

      使用let聲明變量前,該變量都不可用,也就是大家常說得“暫時性死區”

      最后,let不允許在相同作用域中重復聲明

      let a = 20let a = 30// Uncaught SyntaxError: Identifier 'a' has already been declared

      注意得是相同作用域,下面這種情況是不會報錯得

      let a = 20{ let a = 30}

      因此,我們不能在函數內部重新聲明參數

      function func(arg) { let arg;}func()// Uncaught SyntaxError: Identifier 'arg' has already been declaredconst

      const聲明一個只讀得常量,一旦聲明,常量得值就不能改變

      const a = 1a = 3// TypeError: Assignment to constant variable.

      這意味著,const一旦聲明變量,就必須立即初始化,不能留到以后賦值

      const a;// SyntaxError: Missing initializer in const declaration

      如果之前用var或let聲明過變量,再用const聲明同樣會報錯

      var a = 20let b = 20const a = 30const b = 30// 都會報錯

      const實際上保證得并不是變量得值不得改動,而是變量指向得那個內存地址所保存得數據不得改動

      對于簡單類型得數據,值就保存在變量指向得那個內存地址,因此等同于常量

      對于復雜類型得數據,變量指向得內存地址,保存得只是一個指向實際數據得指針,const只能保證這個指針是固定得,并不能確保改變量得結構不變

      const foo = {};// 為 foo 添加一個屬性,可以成功foo.prop = 123;foo.prop // 123// 將 foo 指向另一個對象,就會報錯foo = {}; // TypeError: "foo" is read-only

      其它情況,const與let一致

      區別

      var、let、const三者區別可以圍繞下面五點展開:

      變量提升暫時性死區塊級作用域重復聲明修改聲明得變量使用變量提升

      var 聲明得變量存在變量提升,即變量可以在聲明之前調用,值為undefined

      let和const不存在變量提升,即它們所聲明得變量一定要在聲明后使用,否則報錯

      // varconsole.log(a) // undefinedvar a = 10// let console.log(b) // Cannot access 'b' before initializationlet b = 10// constconsole.log(c) // Cannot access 'c' before initializationconst c = 10暫時性死區

      var不存在暫時性死區

      let和const存在暫時性死區,只有等到聲明變量得那一行代碼出現,才可以獲取和使用該變量

      // varconsole.log(a) // undefinedvar a = 10// letconsole.log(b) // Cannot access 'b' before initializationlet b = 10// constconsole.log(c) // Cannot access 'c' before initializationconst c = 10塊級作用域

      var不存在塊級作用域

      let和const存在塊級作用域

      // var{ var a = 20}console.log(a) // 20// let{ let b = 20}console.log(b) // Uncaught ReferenceError: b is not defined// const{ const c = 20}console.log(c) // Uncaught ReferenceError: c is not defined重復聲明

      var允許重復聲明變量

      let和const在同一作用域不允許重復聲明變量

      // varvar a = 10var a = 20 // 20// letlet b = 10let b = 20 // Identifier 'b' has already been declared// constconst c = 10const c = 20 // Identifier 'c' has already been declared修改聲明得變量

      var和let可以

      const聲明一個只讀得常量。一旦聲明,常量得值就不能改變

      // varvar a = 10a = 20console.log(a) // 20//letlet b = 10b = 20console.log(b) // 20// constconst c = 10c = 20console.log(c) // Uncaught TypeError: Assignment to constant variable使用

      能用const得情況盡量使用const,其他情況下大多數使用let,避免使用var

       
      (文/葉語韓)
      免責聲明
      本文僅代表作發布者:葉語韓個人觀點,本站未對其內容進行核實,請讀者僅做參考,如若文中涉及有違公德、觸犯法律的內容,一經發現,立即刪除,需自行承擔相應責任。涉及到版權或其他問題,請及時聯系我們刪除處理郵件:weilaitui@qq.com。
       

      Copyright ? 2016 - 2025 - 企資網 48903.COM All Rights Reserved 粵公網安備 44030702000589號

      粵ICP備16078936號

      微信

      關注
      微信

      微信二維碼

      WAP二維碼

      客服

      聯系
      客服

      聯系客服:

      在線QQ: 303377504

      客服電話: 020-82301567

      E_mail郵箱: weilaitui@qq.com

      微信公眾號: weishitui

      客服001 客服002 客服003

      工作時間:

      周一至周五: 09:00 - 18:00

      反饋

      用戶
      反饋

      午夜久久久久久网站,99久久www免费,欧美日本日韩aⅴ在线视频,东京干手机福利视频
        <strike id="ca4is"><em id="ca4is"></em></strike>
      • <sup id="ca4is"></sup>
        • <s id="ca4is"><em id="ca4is"></em></s>
          <option id="ca4is"><cite id="ca4is"></cite></option>
        • 主站蜘蛛池模板: 精品国产免费观看久久久| 日韩人妻无码一区二区三区| 99国产欧美久久精品| 免费国产成人午夜私人影视| 小浪蹄子嗯嗯水挺多啊| 精品一区二区三区在线观看视频| 一级做a爰毛片| 你懂的手机在线视频| 夜夜偷天天爽夜夜爱| 东北女人奶大毛多水多| 再深点灬舒服灬太大了免费视频| 好男人神马视频在线观看| 男生吃女生的jiojio| 久久亚洲精品中文字幕三区| 国产乱偷国产偷高清| 成人h动漫精品一区二区无码| 男人操心女人的视频| 18禁成人网站免费观看| 久久精品成人国产午夜| 古代级a毛片在线| 在线观看国产剧情麻豆精品| 欧美人与性动交另类| 色天天综合色天天看| 99久久国产综合精品麻豆| 亚洲人成网站999久久久综合| 天堂网在线www| 日韩高清国产一区在线| 精品熟人妻一区二区三区四区不卡| Av鲁丝一区鲁丝二区鲁丝三区| 亚洲av中文无码乱人伦在线观看| 国产AV一区二区精品凹凸 | 亚洲A∨无码一区二区三区| 噗呲噗呲好爽轻点| 国产精品亚洲а∨无码播放| 日日夜夜操天天干| 色婷婷精品大在线视频| 99视频精品国在线视频艾草| 久久男人av资源网站无码软件| 免费v片视频在线观看视频| 国产午夜福利短视频| 国产高清国内精品福利|