真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

ES6中var、let、const、塊級(jí)作用域以及暫存死區(qū)是什么-創(chuàng)新互聯(lián)

這篇文章將為大家詳細(xì)講解有關(guān)ES6中var、let、const、塊級(jí)作用域以及暫存死區(qū)是什么,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

我們提供的服務(wù)有:做網(wǎng)站、成都做網(wǎng)站、微信公眾號(hào)開(kāi)發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、鼎城ssl等。為數(shù)千家企事業(yè)單位解決了網(wǎng)站和推廣的問(wèn)題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的鼎城網(wǎng)站制作公司var

語(yǔ)法

var varname1 [= value1 [, varname2 [, varname3 ... [, varnameN]]]];

使用

var a, b=2 // 聲明多個(gè)變量,可以賦值,也可以不賦值
a=1 // 先聲明,再賦值

var變量提升

使用var聲明的變量將會(huì)被提升到函數(shù)的頂部

console.log(a) // undefined
var a =2  
console.log(a) // 2
console.log(b) //Uncaught ReferenceError: b is not defined...

以上代碼相當(dāng)于

var a
console.log(a) // undefined
a=2
console.log(a) // 2
console.log(b) //Uncaught ReferenceError: b is not defined...
0x002 let

語(yǔ)法

let var1 [= value1] [, var2 [= value2]] [, ..., varN [= valueN]];

使用

let a, b = 2 // 聲明多個(gè)變量,賦值不賦值無(wú)所謂
a = 2 // 聲明之后再賦值

不再提升

console.log(a) // Uncaught ReferenceError: a is not defined...
let a=1

注意:猜測(cè), 使用babel翻譯一下代碼發(fā)現(xiàn),只是let變成了var,所以使用babel轉(zhuǎn)義之后的代碼依舊會(huì)提升

不能重復(fù)聲明

let a=1
let a=2 // Uncaught SyntaxError: Identifier 'a' has already been declared
const

語(yǔ)言

const name1 = value1 [, name2 = value2 [, ... [, nameN = valueN]]];

使用

const a=1, b=2 // 不能省略的值

不能省略的值

const c // Uncaught SyntaxError: Missing initializer in const declaration

不能重復(fù)賦值

const d=4
d=5 // Uncaught TypeError: Assignment to constant variable.

可以修改的引用

const e=[]
e[0]=0
console.log(e) //[0]
塊級(jí)作用域

塊級(jí)作用域是隨著let、const而來(lái)最有用的特性了,在之前的js中,js的作用域是函數(shù)級(jí)的,由此帶來(lái)的幾個(gè)臭名昭著的問(wèn)題:

意外被修改的值

function varTest() {
  var x = 1;
  if (true) {
    var x = 2;  // 同樣的變量!
    console.log(x);  // 2
  }
  console.log(x);  // 2
}

可以使用let避免了

function letTest() {
  let x = 1;
  if (true) {
    let x = 2;  // 不同的變量
    console.log(x);  // 2
  }
  console.log(x);  // 1
}

萬(wàn)惡的for循環(huán)和點(diǎn)擊事件

var list = document.getElementById("list");

for (var i = 0; i < 5; i++) {
  var item = document.createElement("LI");
  item.appendChild(document.createTextNode("Item " + i));

  item.onclick = function (ev) {
    console.log("Item " +i + " is clicked.");
  };
  list.appendChild(item);
}
console.log(i) // 5

如果點(diǎn)擊上面,不管點(diǎn)擊哪個(gè),顯示出來(lái)的都是Item 5 is clicked.,雖然可以使用閉包解決,但是現(xiàn)在有了更好的方案

let list = document.getElementById("list");

for (let i = 0; i < 5; i++) {
  let item = document.createElement("LI");
  item.appendChild(document.createTextNode("Item " + i));

  item.onclick = function (ev) {
    console.log("Item " +i + " is clicked.");
  };
  list.appendChild(item);
}
作用域規(guī)則很簡(jiǎn)單

{}塊內(nèi)形成一個(gè)作用域,包括if、else、while、classdo...while、{}、function

{
    const f=6
}
console.log(f) // Uncaught ReferenceError: f is not defined

for循環(huán)中用let聲明一個(gè)初始因子,該因子在每個(gè)循環(huán)內(nèi)都是一個(gè)新的作用域

for (let i = 0; i < 10; i++) {
  console.log(i);
}
console.log(i) // Uncaught ReferenceError: i is not defined

switch只有一個(gè)作用域

switch (x) {
  case 0:
    let foo;
    break;
    
  case 1:
    let foo; 
    break;
}
// Uncaught SyntaxError: Identifier 'foo' has already been declared
暫存死區(qū)-Temporal Dead Zone-TDZ

隨著let和const的引入,也引入了暫存死區(qū)的概念。使用var的時(shí)候,作用域內(nèi)(函數(shù)作用域),在還沒(méi)使用var聲明一個(gè)變量的時(shí)候,訪問(wèn)該變量,將會(huì)獲得undefined。但是如果使用let,作用域(塊級(jí)作用域)內(nèi),在還沒(méi)使用let聲明一個(gè)變量的時(shí)候,訪問(wèn)該變量,將會(huì)獲得ReferenceError,從作用域開(kāi)始到let語(yǔ)句之間,就是暫存死區(qū)。

{
 console.log(a) // Uncaught ReferenceError: a is not defined
 console.log(b) // Uncaught ReferenceError: b is not defined
 console.log(c) // undefined
 // 暫存死區(qū)
 let a =1
 const b=2
 var c=3
}

注意:猜測(cè), 使用babel翻譯一下代碼發(fā)現(xiàn),只是let變成了var,所以使用babel轉(zhuǎn)義之后可能不存在暫存死區(qū)

關(guān)于ES6中var、let、const、塊級(jí)作用域以及暫存死區(qū)是什么就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。


當(dāng)前名稱:ES6中var、let、const、塊級(jí)作用域以及暫存死區(qū)是什么-創(chuàng)新互聯(lián)
網(wǎng)站URL:http://weahome.cn/article/dicsog.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部