二維碼
        企資網

        掃一掃關注

        當前位置: 首頁 » 企資快報 » 產品 » 正文

        var_let_const之間的區別

        放大字體  縮小字體 發布日期:2023-05-04 12:09:20    作者:百里韻鏵    瀏覽次數:110
        導讀

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

        一、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 declared三、const

        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

        反饋

        用戶
        反饋

        国产色无码精品视频免费| 天堂资源在线最新版天堂中文| 曰韩无码AV片免费播放不卡| 久久久久亚洲精品中文字幕 | 少妇无码AV无码一区| 日韩网红少妇无码视频香港| 亚洲日韩中文无码久久| 无码人妻精品一区二区三区66 | 久久亚洲精品无码aⅴ大香| 国产高新无码在线观看| 日本在线中文字幕第一视频| 18无码粉嫩小泬无套在线观看 | 中文字幕视频在线| 88久久精品无码一区二区毛片| 五月天中文字幕mv在线女婷婷五月| 日韩乱码人妻无码系列中文字幕 | 免费无码又爽又刺激网站直播| 无码精品人妻一区| 久久精品aⅴ无码中文字字幕不卡| 最近免费中文字幕MV在线视频3 | 久久久这里有精品中文字幕| 国产成人无码午夜福利软件| 中文字幕乱妇无码AV在线| 久久婷婷综合中文字幕| 国产av永久无码天堂影院| 国产亚洲大尺度无码无码专线| 无码内射中文字幕岛国片| 国产啪亚洲国产精品无码| 中文字幕无码第1页| 亚洲精品99久久久久中文字幕| 曰韩无码AV片免费播放不卡| 国产精品无码素人福利不卡| 曰韩精品无码一区二区三区| 乱人伦中文视频高清视频| 一本之道高清无码视频| 18禁黄无码高潮喷水乱伦 | 少妇精品无码一区二区三区 | 狠狠精品久久久无码中文字幕| 成人无码精品1区2区3区免费看| 亚洲av永久无码精品漫画| 一区二区三区在线观看中文字幕 |