es6高级第一天作业

本文详细介绍了ES6中的let命令,包括它与var的区别,如块级作用域、暂时性死区以及变量提升。还讨论了let在for循环中的独特应用,并通过实例展示了let在代码中的正确和错误用法。此外,文章还涉及模板字符串的使用,以及对象解构赋值的相关示例。通过对let的深入理解,有助于编写更安全、更规范的JavaScript代码。
摘要由CSDN通过智能技术生成

1、var和let的区别

1)ES6 新增了let命令,用来声明局部变量。它的用法类似于var,但是所声明的变量,只在let命令所在的代码块内有效,而且有暂时性死区的约束。

var a = 99;            // 全局变量a

f();                   // f是函数,虽然定义在调用的后面,但是函数声明会提升到作用域的顶部。

console.log(a);        // a=>99,  此时是全局变量的a

function f() {

  console.log(a);      // 当前的a变量是下面变量a声明提升后,默认值undefined

  var a = 10;

  console.log(a);      // a => 10

}

 

// 输出结果:

undefined

10

99

2)ES6之前,我们都是用var来声明变量,而且JS只有函数作用域和全局作用域,没有块级作用域,所以{}限定不了var声明变量的访问范围。

{ 
  var i = 9;
} 
console.log(i);  // 9

ES6新增的let,可以声明块级作用域的变量。

{ 
  let i = 9;     // i变量只在 花括号内有效!!!
} 
console.log(i);  // Uncaught ReferenceError: i is not defined

3)let配合for循环的独特应用

let非常适合用于 for循环内部的块级作用域。JS中的for循环体比较特殊,每次执行都是一个全新的独立的块作用域,用let声明的变量传入到 for循环体的作用域后,不会发生改变,不受外界的影响。

for (var i = 0; i <10; i++) {  
  setTimeout(function() {  // 同步注册回调函数到 异步的 宏任务队列。
    console.log(i);        // 执行此代码时,同步代码for循环已经执行完成
  }, 0);
}
// 输出结果
10   10
// 这里面的知识点: JS的事件循环机制,setTimeout的机制等

如果把 var改成 let声明:

// i虽然在全局作用域声明,但是在for循环体局部作用域中使用的时候,变量会被固定,不受外界干扰。
for (let i = 0; i < 10; i++) { 
  setTimeout(function() {
    console.log(i);    //  i 是循环体内局部作用域,不受外界影响。
  }, 0);
}
// 输出结果:
0  1  2  3  4  5  6  7  8 9

4)let没有变量提升与暂时性死区

let声明的变量,不存在变量提升。而且要求必须 let声明语句执行完之后,变量才能使用,不然会报Uncaught ReferenceError错误。

console.log(aicoder);    // 错误:Uncaught ReferenceError ...
let aicoder = 'aicoder.com';
// 这里就可以安全使用aicoder

ES6 明确规定,如果区块中存在letconst命令,这个区块对这些命令声明的变量,从一开始就形成了封闭作用域。凡是在声明之前就使用这些变量,就会报错。
总之,在代码块内,使用let命令声明变量之前,该变量都是不可用的。这在语法上,称为暂时性死区temporal dead zone,简称 TDZ)。

5let变量不能重复声明

let不允许在相同作用域内,重复声明同一个变量。否则报错:Uncaught SyntaxError: Identifier 'XXX' has already been declared

let a = 0;
let a = 'sss';
// Uncaught SyntaxError: Identifier 'a' has already been declared

 

总结:

ES6letjs真正拥有了块级作用域,也是向这更安全更规范的路走,虽然加了很多约束,但是都是为了让我们更安全的使用和写代码。

 

2、分析代码执行结果?

var a=123;

if(true){

a='zsh';

let a;

}

答:报错:在声明之前  不能使用变量:a

 

3、补全代码

var person={

name:'zs',

age:12

}

let str=`                         `;

结果呈现:用户的姓名为 ,年龄是

result.innerHTML=str;

答:str=`用户的姓名为${person.name},年龄是${person.age}`

 

4、将下面字符串改用模板字符串实现?

$("#result").append(

"He is <b>"+person.name+"</b>"+"and we wish to

know his"+person.age+".That is all"  )

答:$("#result").append(

` He is <b>${person.name}</b>"+"and we wish to

know his ${person.age}.That is all" `

 )

 

5、下面程序输出的结果是?

let object = { first: 'Bill', lasts: 'Gates' };

let { first: firstName, last: lastName } = object;

console.log(firstName+'\t'+lastName);

答:Bill  undefined

 

6、下列程序执行f()函数运行的结果是?

var tmp = new Date();

function f(){

  console.log(tmp);

  if (false){

    var tmp = "hello world";

  }

}

f()

答:在函数作用域类,相当于声明了一个新的tmp变量,没有赋值。

所以输出:undefined

 

7、对比以下两道程序输出的值相同吗?

//A程序:

var a = [];

for (let i = 0; i < 10; i++) {

  a[i] = function () {

    console.log(i);

  };

}

a[8]();

a[9]();

 

//B程序

var a = [];

for (var i = 0; i < 10; i++) {

  a[i] = function () {

    console.log(i);

  };

}

a[8]();

a[9]();

 

答:A代码段输出:8,9

        B代码段输出:10,10

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值