let var const

本文详细讲解了JavaScript中变量提升、var与let/const的区别、重复声明的后果、暂时性死区以及块级作用域。特别强调了var的特殊性与let和const的限制,对于开发者理解JavaScript作用域规则至关重要。
摘要由CSDN通过智能技术生成

   1.是否存在变量提升?
var声明的变量存在变量提升(将变量提升到当前作用域的顶部)。
即变量可以在声明之前调用,值为undefined。
let和const不存在变量提升。即它们所声明的变量一定要在声明后使用,
否则报ReferenceError错。

2.重复声明

《1》 声明后未赋值不同的表现

   



var varTest;
  let letTest;
  console.log(varTest); //输出undefined
  console.log(letTest); //输出undefined

也就是说  声明后输出的都是一样的  undefined

《2》 使用为生命的变量 

  
 console.log(varTest); //输出undefined
  console.log(letTest); //直接报错:ReferenceError: letTest is not defined

未声明的var会输出一个undefined   let 会直接报错

《3》 重复声明时的不同

var varTest = ' var OK';
  let letTest = 'let OK';
 
  var varTest = 'varTest ';
  let letTest = 'letTest '; //直接报错:SyntaxError: Identifier 'letTest' has already been declared
 
  console.log(varTest); //输出varTest 
  console.log(letTest);



 let  重复声明会报错   

var 重复声明后面的会覆盖掉前面的声明

 总的来说var允许重复声明变量。let和const在同一作用域不允许重复声明变量。

3.是否存在暂时性死区?
let和const存在暂时性死区。
即只要块级作用域内存在let命令,它所声明的变量就“绑定”(binding)这个区域,
不再受外部的影响。

4.是否存在块级作用域?
var不存在块级作用域。
let和const存在块级作用域

5.是否能修改声明的变量?
var和let可以。
const声明一个只读的常量。一旦声明,常量的值就不能改变。
const声明的变量不得改变值,这意味着,
const一旦声明变量,就必须立即初始化,不能留到以后赋值。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值