欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

深入淺析var,let,const的異同點(diǎn)

 更新時(shí)間:2018年08月07日 08:52:54   作者:唱歌去旅行8  
這篇文章主要介紹了var,let,const異同點(diǎn),文中較詳細(xì)的給大家介紹了let和const的相同點(diǎn)和不同點(diǎn),需要的朋友可以參考下

一、let和var區(qū)別

1.關(guān)于變量提升,var能變量提升,let不能

 // 關(guān)于var 如下所示
console.log(a); //輸出undefined,此時(shí)就是變量提升
var a = 2;  
console.log(a); //2

//相當(dāng)于下面的代碼
var a; //聲明且初始化為undefined
console.log(a); //輸出undefined
a=2;    //賦值
console.log(a); //2

// 關(guān)于let 如下所示
console.log(a); // 報(bào)錯(cuò)ReferenceError
let a = 2;
//相當(dāng)于在第一行先聲明a但沒(méi)有初始化,直到賦值時(shí)才初始化

//直接用let聲明變量不賦值是會(huì)打印undefined,這時(shí)候初始化了
let a;
console.log(a);//值為undefined

2.暫時(shí)性死區(qū):塊級(jí)作用域內(nèi)存在let命令,它所聲明的變量就“綁定”這個(gè)區(qū)域,不再受外部的影響重點(diǎn)內(nèi)容,簡(jiǎn)而言之,就是某個(gè)代碼塊有l(wèi)et指令,即使外部有名稱相同的變量,該代碼塊的同名變量與外部的變量也互不干擾。而var不會(huì),如下所示:

//let
var a = 123;
if (true) {
 let a="abc";
 console.log(a); //輸出abc 
}
console.log(a);  //輸出值為123,全局a與局部a互不影響

//var
var a = 123;
if (true) {
 var a="abc";
 console.log(a); //輸出abc 
}
console.log(a);  //輸出值為abc,全局的已被改變

總之,在代碼塊內(nèi),使用let命令聲明變量之前,該變量都是不可用的。這在語(yǔ)法上,稱為“暫時(shí)性死區(qū)”(temporal dead zone,簡(jiǎn)稱 TDZ)。例子如下:

var tmp=1;
if (true) {
 // TDZ開(kāi)始
 tmp = 'abc'; // ReferenceError
 console.log(tmp); // ReferenceError

 let tmp; // TDZ結(jié)束
 console.log(tmp); // undefined

 tmp = 123;
 console.log(tmp); // 123
}
console.log(tmp); // 

3.let聲明綁定的代碼塊內(nèi),不能重復(fù)聲明同一個(gè)變量,var可以

//a不能重復(fù)聲明
function sub() {
 let a = 10;
 var a = 1;
}  //報(bào)錯(cuò),Identifier 'a' has already been declared

function sub() {
 let a = 10;
 let a = 1;
}  //同上

function sub() {
 let a = 10;
 {let a = 1;} //此時(shí)不在同一個(gè)代碼塊,不會(huì)報(bào)錯(cuò)
} 

//var可以重復(fù)聲明,不會(huì)報(bào)錯(cuò)
function sub() {
 var a = 10;
 var a = 1;
}

4.類似for循環(huán)的代碼塊,let只在代碼塊內(nèi)部有效,var在代碼塊外部也有效

//let只在代碼塊內(nèi)部有效
for (let i = 0; i < 10; i++) {}
console.log(i); //報(bào)錯(cuò)ReferenceError: i is not defined

//var在代碼塊外部也有效
for (let i = 0; i < 10; i++) {}
console.log(i); //101

let在for循環(huán)內(nèi)特別之處:就是設(shè)置循環(huán)變量的那部分是一個(gè)父作用域,而循環(huán)體內(nèi)部是一個(gè)單獨(dú)的子作用域。
//只在父作用域
var a = [];
for (let i = 0; i < 10; i++) {
 a[i] = function () {
  console.log(i);
 };
}
a[6](); // 6

//子作用域重新聲明
var a = [];
for (let i = 0; i < 10; i++) {
 a[i] = function () {
   let i=3; //重新賦值
   console.log(i);
 };
}
a[6](); // 3 ,取得新的值

二、let和const

1、相同點(diǎn):

A、變量不提升。
B、暫時(shí)性死區(qū),只能在聲明的位置后面使用。
C、不可重復(fù)聲明。

2、不同點(diǎn):

let聲明的變量可以改變。
const聲明一個(gè)只讀的常量。一旦聲明,常量的值就不能改變,且聲明的時(shí)候必須初始化賦值。
let a;  //undefined
const b;//報(bào)錯(cuò),聲明的時(shí)候必須賦值

let a=1;
a=2;    //可改變

const b=1;
b=2;    //報(bào)錯(cuò),不能改變值

//一些自己覺(jué)得要注意的點(diǎn)
let a=null;         //a=null
a=undefined;    //a=undefined
a=2;            //a=2
const a=null;   //a=null,const也可以定義null和undefined
const b=undefined;   //b=undefined
b=2;            //報(bào)錯(cuò),不能改變值

本質(zhì):

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

A、五種基本數(shù)據(jù)類型(Number,String,Boolean,Undefined,Null):值就保存在變量指向的那個(gè)內(nèi)存地址,等同于常量。不能改變值。

B、復(fù)雜數(shù)據(jù)類型(Object:數(shù)組、對(duì)象):該類型變量名不指向數(shù)據(jù),而是指向數(shù)據(jù)所在的地址,const只保證變量名指向的地址不變,并不保證改地址的數(shù)據(jù)不變,因此可以對(duì)該地址的屬性值進(jìn)行修改,但是不能改變地址指向。

const a=[];
a.push("Hello"); //可執(zhí)行,改地址的屬性值可以修改
a.length=0;   //可執(zhí)行,同上
a=["Tom"];   //報(bào)錯(cuò),不能改變地址指向

const b ={};
b.prop=123;   //為b添加一個(gè)屬性,可以成功
b.prop    //123
b={};    //將b指向另外一個(gè)地址,就會(huì)報(bào)錯(cuò)

如果真的想將對(duì)象凍結(jié),應(yīng)該使用Object.freeze方法。
const b=Object.freeze({});
// 常規(guī)模式時(shí),下面一行不起作用,b.prop為undefined
// 嚴(yán)格模式時(shí),該行會(huì)報(bào)錯(cuò)
b.prop = 123;

總結(jié)

以上所述是小編給大家介紹的var,let,const的異同點(diǎn),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 利用JavaScript做數(shù)獨(dú)的完整實(shí)現(xiàn)過(guò)程

    利用JavaScript做數(shù)獨(dú)的完整實(shí)現(xiàn)過(guò)程

    數(shù)獨(dú)游戲是在一個(gè)9*9的方格中進(jìn)行填數(shù)字的游戲,需要滿足的規(guī)則是每行每列和每個(gè)子九宮格都是1~9的不重復(fù)數(shù)字,下面這篇文章主要給大家介紹了關(guān)于如何利用JavaScript做數(shù)獨(dú)的相關(guān)資料,需要的朋友可以參考下
    2021-09-09
  • 微信小程序 checkbox使用實(shí)例解析

    微信小程序 checkbox使用實(shí)例解析

    這篇文章主要介紹了微信小程序 checkbox使用實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-09-09
  • JS開(kāi)發(fā)中基本數(shù)據(jù)類型具體有哪幾種

    JS開(kāi)發(fā)中基本數(shù)據(jù)類型具體有哪幾種

    JS的數(shù)據(jù)類型包括基本數(shù)據(jù)類型、復(fù)雜數(shù)據(jù)類型和特殊數(shù)據(jù)類型,今天我們主要先講解一下基本數(shù)據(jù)類型。感興趣的朋友一起看看吧
    2017-10-10
  • 微信小程序使用map組件實(shí)現(xiàn)解析經(jīng)緯度功能示例

    微信小程序使用map組件實(shí)現(xiàn)解析經(jīng)緯度功能示例

    這篇文章主要介紹了微信小程序使用map組件實(shí)現(xiàn)解析經(jīng)緯度功能,涉及微信小程序map組件結(jié)合高德地圖進(jìn)行經(jīng)緯度獲取相關(guān)操作技巧,需要的朋友可以參考下
    2019-01-01
  • JavaScript 申明函數(shù)的三種方法 每個(gè)函數(shù)就是一個(gè)對(duì)象(一)

    JavaScript 申明函數(shù)的三種方法 每個(gè)函數(shù)就是一個(gè)對(duì)象(一)

    JavaScript 申明函數(shù)的三種方法 每個(gè)函數(shù)就是一個(gè)對(duì)象(一)
    2009-12-12
  • 微信小程序連接數(shù)據(jù)庫(kù)與WXS的使用方法詳細(xì)介紹

    微信小程序連接數(shù)據(jù)庫(kù)與WXS的使用方法詳細(xì)介紹

    這篇文章主要介紹了微信小程序連接數(shù)據(jù)庫(kù)與WXS的使用方法,微信小程序是騰訊內(nèi)部的產(chǎn)品,不能直接打開(kāi)一個(gè)外部的鏈接,但是騰訊為開(kāi)發(fā)者封裝好了API用來(lái)請(qǐng)求一個(gè)網(wǎng)站的內(nèi)容或者服務(wù),感興趣的同學(xué)可以參考下
    2023-12-12
  • JS中浮點(diǎn)數(shù)精度問(wèn)題的分析與解決方法

    JS中浮點(diǎn)數(shù)精度問(wèn)題的分析與解決方法

    在js中我們有時(shí)會(huì)遇到計(jì)算,通過(guò)加減乘除處理某些業(yè)務(wù),那么這時(shí)候如果不做任何處理,就會(huì)出現(xiàn)如下典型的精度丟失問(wèn)題,下面這篇文章主要給大家介紹了關(guān)于JS中浮點(diǎn)數(shù)精度問(wèn)題的分析與解決方法,需要的朋友可以參考下
    2022-04-04
  • 最新評(píng)論