站長資訊網
        最全最豐富的資訊網站

        一起聊聊var、let以及const的區別(代碼示例)

        本篇文章給大家帶來了關于JavaScript的相關知識,其中主要給大家介紹了var、let以及const的區別有哪些,還有ECMAScript 和 JavaScript的關系介紹,感興趣的朋友一起來看一下吧,希望對大家有幫助。

        一起聊聊var、let以及const的區別(代碼示例)

        什么是JavaScript?

        首先,ECMAScript 和 JavaScript 什么關系?

        • ECMAScript是一個國際通過的標準化腳本語言。
        • JavaScript由ECMAScript和DOM、BOM三者組成。 可以簡單理解為:ECMAScript是JavaScript的語言規范,JavaScript是ECMAScript的實現和擴展。

        var、let、const的區別?

        1. var聲明變量存在變量提升,let和const不存在變量提升

        console.log(a); // undefined  ===>  a已聲明還沒賦值,默認得到undefined值 console.log(b); // 報錯:b is not defined  ===> 找不到b這個變量 console.log(c); // 報錯:c is not defined  ===> 找不到c這個變量 var a = 100;	 let b = 10; const c = 10; console.log(a);//a=100
        登錄后復制

        2. let和const只能在塊作用域里訪問

        if(1){     var a = 100;     let b = 10;     const c = 1; }  console.log(a); // 100 console.log(b)  // 報錯:b is not defined  ===> 找不到b這個變量 console.log(c)  // 報錯:c is not defined  ===> 找不到c這個變量
        登錄后復制

        3. 同一作用域下let和const不能聲明同名變量,而var可以

        var a = 100; console.log(a); //控制臺輸出 100  var a = 10; console.log(a); //控制臺輸出 10  let a = 100; let a = 10;  //  控制臺報錯:Identifier 'a' has already been declared  ===> 標識符a已經被聲明了。
        登錄后復制

        4. const定義常量,而且不能修改,但是在定義的對象時對象屬性值可以改變

         const a=2  a=3  console.log(a)  //控制臺報錯
        登錄后復制

        const person = {     name : 'make',     sex : '男' }  person.name = 'test'  console.log(person.name)    //運行發現控制臺沒有報錯,且 person.name 被成功修改
        登錄后復制

        ????這是怎么回事呢?

        因為對象是引用類型的,person中保存的僅是對象的指針,而修改對象的屬性不會改變對象的指針,所以這種情況就會修改成功。也就是說const定義的引用類型只要指針不發生改變,都是被允許的。

        接下來我們試著修改一下指針,讓person指向一個新對象,最后果然報錯

        const person = {   name : 'make',   sex : '男'}person = {   name : 'test',   sex : '男'}console.log(person.name)  //控制臺報錯
        登錄后復制

        5. 小結

        • var定義的變量變量提升,沒有塊的概念,可以跨塊訪問

        • let定義的變量只能在塊作用域里訪問,不能聲明同名變量。

        • const用來定義常量,使用時必須初始化(即必須賦值),不能聲明同名變量,只能在塊作用域里訪問,而且不能修改,但是在定義的對象時對象屬性值可以改變。

        • 他們都不能跨函數訪問

        推薦學習:《JavaScript視頻教程》

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 欧美久久久久久午夜精品| 日韩精品人成在线播放| 国模精品一区二区三区| 国产女人精品视频国产灰线| 精品福利一区二区三区精品国产第一国产综合精品 | 老司机国内精品久久久久| 人人妻人人澡人人爽人人精品 | 中文字幕一精品亚洲无线一区 | 国产亚洲精品精华液| 亚洲国产精品尤物YW在线观看| 国产精品 视频一区 二区三区| 国产精品网址在线观看你懂的| 久久精品国产只有精品66| 3级黄性日本午夜精品| 99久久婷婷免费国产综合精品| 色一乱一伦一图一区二区精品 | 囯产精品一区二区三区线| 精品成人免费自拍视频| jizz国产精品网站| 精品一区二区三区无码免费视频 | 久久99国产精品成人欧美| 国产激情精品一区二区三区| 色偷偷888欧美精品久久久| 九九热精品在线| 国内精品在线视频| 国内精品久久九九国产精品| 国产精品v欧美精品v日韩精品 | 国产精品兄妹在线观看麻豆| 久久久久国产精品熟女影院| 亚洲国产精品视频| 亚洲精品永久在线观看| 亚洲日韩欧美制服精品二区| 亚洲av无码成人精品区在线播放 | 国产精品丝袜一区二区三区| 精品国精品国产自在久国产应用| 无码精品一区二区三区在线| 亚洲人成精品久久久久| 日韩人妻无码精品久久免费一| 麻豆aⅴ精品无码一区二区| 国内精品人妻无码久久久影院 | 日韩精品久久久久久免费|