日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

本篇文章給大家帶來了關于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用來定義常量,使用時必須初始化(即必須賦值),不能聲明同名變量,只能在塊作用域里訪問,而且不能修改,但是在定義的對象時對象屬性值可以改變。

他們都不能跨函數訪問


分享到:
標簽:var、let以及const的區別
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定