ES6学习——2.let与const

一.let声明特性

1.不存在变量提升,即他所声明的变量一定要在变量声明后使用

var 情况
console.log(song);
var song = ‘恋爱达人’; //undefined
let情况
console.log(song);
let song = ‘恋爱达人’; //ReferenceError(报错)

2.暂时性死区(temporal dead zone——TDZ)

只要块级作用域内存在let命令,它所声明的变量就绑定这个区域,不再受外部影响,总之,在代码内,使用let命令声明变量之前,该变量都是不可以用的

if(true){
TZD开始
tmp=‘abc’; //ReferenceError
console.log(tmp); //ReferenceError
let tmp; //TZD结束
tmp=‘abc’;
console.log(tmp);//abc
}
暂时性死区也意味着typeof不再是一个百分百操作
情况1
tyepeof x; //ReferenceError
let x;
情况2
(r如果一个变量没有声明,使用typeof不会报错)
typeof x; //undefined;
情况三
var x=x;
let x=x; ×

3.不允许重复声明

function fn(){
let a=10
var a=1
} //报错
不能在函数内部重新声明参数
function fn(arg){
let arg;
}
fn(); //报错
function fn(arg){
{ let arg;}
}
fn(); //不报错

4.块级作用域,声明的变量仅在块级作用域有效

var a = [];
for (var i = 0; i < 10; i++) {
a[i] = function () {
console.log(i);
};
}
//i是var声明的全局变量,
a[7]();//10
let A = [];
for (let i = 0; i < 10; i++) {
A[i] = function () {
console.log(i);
};
}
//i只在块级作用域内有效
A[7]();//7

二.const命令

const声明的一个只读的常量,一旦声明,常量的值就不能改变。

1.一定要赋初始值;

const A=‘小红’

2.一般常量使用大写(潜规则,无硬性要求);
3.常量的值不能修改;

const A=‘小红’;
A=‘小兰’ //报错

4.块儿级作用域

if(true){
const A=‘小红’;
}
A; //undefined

5.暂时性死区

if(true){
console.log(A);
const A=‘小红’;
} //报错

6.对于数组和对象元素修改,不报错

,因为const本质上并不是变量的值不得变动,而是变量指向的那个内存地址所保存的值不能改动,对于发咋类型数据(主要是对象,数组)来说,变量指向的是内存地址,保存的只是一个指向实际数据的指针。

const foo={};
//添加属性
foo.prop=123;
console.log(foo.prop);

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值