二維碼
        企資網(wǎng)

        掃一掃關(guān)注

        當(dāng)前位置: 首頁(yè) » 企資快報(bào) » 科普知識(shí) » 正文

        var_let_const之間的區(qū)別

        放大字體  縮小字體 發(fā)布日期:2023-05-04 12:09:20    作者:百里韻鏵    瀏覽次數(shù):102
        導(dǎo)讀

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

        一、var

        在ES5中,頂層對(duì)象得屬性和全局變量是@價(jià)得,用var聲明得變量既是全局變量,也是頂層變量

        注意:頂層對(duì)象,在瀏覽器環(huán)境指得是window對(duì)象,在 Node 指得是global對(duì)象

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

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

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

        在敬請(qǐng)關(guān)注譯階段,敬請(qǐng)關(guān)注譯器會(huì)將其變成以下執(zhí)行

        var aconsole.log(a)a = 20

        使用var,我們能夠?qū)σ粋€(gè)變量進(jìn)行多次聲明,后面聲明得變量會(huì)覆蓋前面得變量聲明

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

        在函數(shù)中使用使用var聲明變量時(shí)候,該變量是局部得

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

        而如果在函數(shù)內(nèi)不使用var,該變量是全局得

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

        let是ES6新增得命令,用來(lái)聲明變量

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

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

        不存在變量提升

        console.log(a) // 報(bào)錯(cuò)ReferenceErrorlet a = 2

        這表示在聲明它之前,變量a是不存在得,這時(shí)如果用到它,就會(huì)拋出一個(gè)錯(cuò)誤

        只要塊級(jí)作用域內(nèi)存在let命令,這個(gè)區(qū)域就不再受外部影響

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

        使用let聲明變量前,該變量都不可用,也就是大家常說(shuō)得“暫時(shí)性死區(qū)”

        最后,let不最優(yōu)在相同作用域中重復(fù)聲明

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

        注意得是相同作用域,下面這種情況是不會(huì)報(bào)錯(cuò)得

        let a = 20{ let a = 30}

        因此,我們不能在函數(shù)內(nèi)部重新聲明參數(shù)

        function func(arg) { let arg;}func()// Uncaught SyntaxError: Identifier 'arg' has already been declared三、const

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

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

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

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

        如果之前用var或let聲明過(guò)變量,再用const聲明同樣會(huì)報(bào)錯(cuò)

        var a = 20let b = 20const a = 30const b = 30// 都會(huì)報(bào)錯(cuò)

        const實(shí)際上保證得并不是變量得值不的改動(dòng),而是變量指向得那個(gè)內(nèi)存地址所保存得數(shù)據(jù)不的改動(dòng)

        對(duì)于簡(jiǎn)單類(lèi)型得數(shù)據(jù),值就保存在變量指向得那個(gè)內(nèi)存地址,因此@同于常量

        對(duì)于復(fù)雜類(lèi)型得數(shù)據(jù),變量指向得內(nèi)存地址,保存得只是一個(gè)指向?qū)嶋H數(shù)據(jù)得指針,const只能保證這個(gè)指針是固定得,并不能確保改變量得結(jié)構(gòu)不變

        const foo = {};// 為 foo 添加一個(gè)屬性,專(zhuān)業(yè)成功foo.prop = 123;foo.prop // 123// 將 foo 指向另一個(gè)對(duì)象,就會(huì)報(bào)錯(cuò)foo = {}; // TypeError: "foo" is read-only

        其它情況,const與let一致

        四、區(qū)別

        var、let、const三者區(qū)別專(zhuān)業(yè)圍繞下面五點(diǎn)展開(kāi):

        變量提升暫時(shí)性死區(qū)塊級(jí)作用域重復(fù)聲明修改聲明得變量使用變量提升

        var 聲明得變量存在變量提升,即變量專(zhuān)業(yè)在聲明之前調(diào)用,值為undefined

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

        // 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暫時(shí)性死區(qū)

        var不存在暫時(shí)性死區(qū)

        let和const存在暫時(shí)性死區(qū),只有@到聲明變量得那一行代碼出現(xiàn),才專(zhuān)業(yè)獲取和使用該變量

        // 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塊級(jí)作用域

        var不存在塊級(jí)作用域

        let和const存在塊級(jí)作用域

        // 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重復(fù)聲明

        var最優(yōu)重復(fù)聲明變量

        let和const在同一作用域不最優(yōu)重復(fù)聲明變量

        // 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專(zhuān)業(yè)

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

        // 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,其他情況下大多數(shù)使用let,避免使用var

         
        (文/百里韻鏵)
        打賞
        免責(zé)聲明
        本文為百里韻鏵推薦作品?作者: 百里韻鏵。歡迎轉(zhuǎn)載,轉(zhuǎn)載請(qǐng)注明原文出處:http://www.sneakeraddict.net/qzkb/show-114238.html 。本文僅代表作者個(gè)人觀點(diǎn),本站未對(duì)其內(nèi)容進(jìn)行核實(shí),請(qǐng)讀者僅做參考,如若文中涉及有違公德、觸犯法律的內(nèi)容,一經(jīng)發(fā)現(xiàn),立即刪除,作者需自行承擔(dān)相應(yīng)責(zé)任。涉及到版權(quán)或其他問(wèn)題,請(qǐng)及時(shí)聯(lián)系我們郵件:weilaitui@qq.com。
         

        Copyright ? 2016 - 2023 - 企資網(wǎng) 48903.COM All Rights Reserved 粵公網(wǎng)安備 44030702000589號(hào)

        粵ICP備16078936號(hào)

        微信

        關(guān)注
        微信

        微信二維碼

        WAP二維碼

        客服

        聯(lián)系
        客服

        聯(lián)系客服:

        在線QQ: 303377504

        客服電話: 020-82301567

        E_mail郵箱: weilaitui@qq.com

        微信公眾號(hào): weishitui

        客服001 客服002 客服003

        工作時(shí)間:

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

        反饋

        用戶
        反饋

        无码AV波多野结衣久久| 中文字幕在线观看| 久久丝袜精品中文字幕| 亚洲AV无码国产精品麻豆天美 | 亚洲AV中文无码乱人伦下载| 欧美日韩中文国产va另类电影| 午夜不卡久久精品无码免费 | 刺激无码在线观看精品视频| 在线天堂中文在线资源网| 无码av最新无码av专区| 色综合天天综合中文网| 国产成年无码久久久久毛片| avtt亚洲一区中文字幕| 国产精品无码一区二区三级| 人妻精品久久久久中文字幕 | 精品爆乳一区二区三区无码av| 狠狠干中文字幕| 777久久精品一区二区三区无码 | 中文字幕精品无码一区二区三区 | 中出人妻中文字幕无码| 亚洲最大激情中文字幕| 人妻丰满熟妞av无码区| 亚洲日本va午夜中文字幕久久 | 久久精品中文字幕一区| 亚洲AV无码成人精品区大在线| 亚洲精品无码乱码成人| 日本精品久久久久中文字幕| 日韩人妻无码精品无码中文字幕| 伊人久久综合无码成人网 | 综合无码一区二区三区| 无码人妻丰满熟妇区免费| 最近免费中文字幕大全免费| 亚洲AV中文无码乱人伦| 免费A级毛片无码专区| 久久久久精品国产亚洲AV无码| 最近更新中文字幕在线| 精品久久亚洲中文无码| 人妻一区二区三区无码精品一区 | 精品无码一区二区三区爱欲| 最新无码A∨在线观看| 日本欧美亚洲中文|