91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

var、let及const的區別是什么

發布時間:2023-01-06 17:32:23 來源:億速云 閱讀:208 作者:iii 欄目:web開發

這篇文章主要介紹了var、let及const的區別是什么的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇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用來定義常量,使用時必須初始化(即必須賦值),不能聲明同名變量,只能在塊作用域里訪問,而且不能修改,但是在定義的對象時對象屬性值可以改變。

  • 他們都不能跨函數訪問

關于“var、let及const的區別是什么”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“var、let及const的區別是什么”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

长沙县| 太仓市| 墨玉县| 吉木萨尔县| 龙海市| 长子县| 新丰县| 故城县| 星子县| 广西| 当阳市| 左权县| 昌江| 富川| 西和县| 抚宁县| 北票市| 南康市| 奈曼旗| 翼城县| 平阳县| 嵊州市| 望都县| 邮箱| 本溪市| 吉林省| 达孜县| 仁化县| 洮南市| 河津市| 喜德县| 靖宇县| 开远市| 海兴县| 陆河县| 靖江市| 纳雍县| 屏边| 宜兴市| 岗巴县| 昌平区|