var let和const

本文详细介绍了JavaScript中的变量声明关键字var、let和const的区别。var存在变量提升和作用域穿透,let解决了这些问题,提供块级作用域,而const用于声明不可变的常量。在实际开发中,推荐优先使用const,然后是let,避免使用var以减少全局变量污染。此外,let和const都不会在全局作用域中挂载到window对象上。
摘要由CSDN通过智能技术生成

var 、 let 、 const 都是js语言用来声明一个变量的关键字

var 声明作用域
function test (){
	var message = "hi";
}
test();
console.log(message);// Uncaught ReferenceError: message is not defined

使用var在方法中定义的变量会成为局部变量,在方法外使用会报错

function test(){
	message = "hi";
}
test();
console.log(message);//hi

不使用操作符也可以定义变量,而且不受到代码块限制,是全局变量,但这么做会造成项目难以维护,全局变量容易受到污染,在严格模式下,会抛出ReferenceError

"use strict"
function test(){
	message = "hi";
}
test();
console.log(message);//ReferenceError: dasd is not defined	
var 声明提升
function foo() {
	conslone.log(age);
	var age = 18;
}
foo()//undefined

使用var定义变量时,在定义之前使用不会报错,因为var关键字会将变量提升到函数作用域顶部
var 也可以反复多次被定义而不会报错(自己去试)

let声明

letvar的区别
let 声明的范围是块作用域 ,var 是函数作用域

if (true) {
	var name = "chenyu";
	console.log(name);//chenyu
}
console.log(name);//chenyu

if (true) {
	let cName = "晨昱";
	console.log(cName);//晨昱
}
console.log(cName);//ReferenceError: cName is not defined

注意此处 , if 是一个代码块,而不是一个函数,所以var可以穿透代码块,而let 不可以
由于var的此特性会导致变量被污染,所以在实际项目中 let 应该优先于 var

let 暂时性死区

这个概念很好理解,就是let不会进行声明提升,所以在定义let 变量前使用会报错

 ReferenceError: xxx is not defined
全局声明

就是var定义的会被挂到window对象上,let不会

const

常量。。。。。
对对象没用,对象用Object.freeze()这个

关于他们三个的优先使用
const > let > var
let 和var 对照上述特性就知道了
至于const 红宝书上说什么让浏览器运行时强制保持不变。。。
反正优先使用const就对了

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

土拔鼠旱懒

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值