Js中的var、let、const有什么区别?

简介: Js中的var、let、const有什么区别?

网络异常,图片无法展示
|



1、前言


在前面的学习中,我们用到过var、let、const去定义变量,那么它们定义的变量之间到底有什么区别呢?今天我们就一起来看看。


2、快速开始


2.1、关于作用域


首先,var定义的变量是没有作用域的;但let和const定义的变量只能在当前块中使用。


{var a=1,b=2} // 块,块中var定义的变量可以在其他块和块外使用
function adds(a,b){
    return a+b
}
console.log(adds(a,b))
// 输出:3
复制代码


{let a=1,b=2} // 块,块中let定义的变量只能在当前块中使用
function adds(arg1,arg2){
    return arg1+arg2
}
console.log(adds(a,b))
// 输出:ReferenceError: a is not defined
复制代码


{const a=1,b=2} // 块,块中const定义的变量只能在当前块中使用
function adds(arg1,arg2){
    return arg1+arg2
}
console.log(adds(a,b))
// 输出:ReferenceError: a is not defined
复制代码


2.2、关于是否可以重复声明的


var声明的变量是可以重复声明的,新的值会覆盖掉旧的值。但是let和const声明的变量是不能重复声明的。


var a=0,b=1
var a=1
console.log(a+b)
// 输出:2
复制代码


let a=0,b=1
let a=1
console.log(a+b)
// 输出:SyntaxError: Identifier 'a' has already been declared
复制代码


const a=0,b=1
const a=1
console.log(a+b)
// 输出:SyntaxError: Identifier 'a' has already been declared
复制代码


2.3、是否可以变量提升


var声明的变量是可以变量提升的,但是let和const声明的变量是不能变量提升的。


变量提升就是先用变量后声明变量,变量提升的原理就是:Js在运行前会先将var和function的对象提前进行声明和定义,所以就算声明在后也不影响代码的自上而下执行。


var b=2
a=2
console.log(a+b)
var a
// 输出:4
复制代码


3、var的缺点


从上面的对我们有种错觉,var比let和const更好?并不是,你会发现实际开发中,let和const的使用频率比var高,这是为什么呢?因为var存在一些缺点,我们一起来看看。


3.1、没有作用域


这个特点在某个角度来看是优点,但也是缺点。现代化的编程思想中对变量的作用域要求比较严格,一般都是遵循小范围原则。所以var声明的变量没有作用域是其较大的缺点。


3.2、自动添加为window属性


var声明的变量会自动添加为window的属性,这在开发者看来属于对window属性的侵入,是不被提倡的,所以这也是var的缺点。


> window.Cache
< ƒ Cache() { [native code] }
> var Cache='phyger';
< undefined
> window.Cache
< 'phyger'
复制代码


如上,使用var定义的变量修改了window的Cache属性,将原本的Cache方法替换成了一个字符串,这是很不好的。


3.3、提前装载


因为var定义的变量会在代码运行前提前装载,这就导致块中的同名变量会覆盖掉var定义的全局变量,这也是非常糟糕的。


var name = '大马猴';
console.log(name);
function sayhi() {
    console.log('hi-1', name) // name在这个块中生效,所以此时name还未定义
    let name = 'phyger'; // let定义的变量在代码执行到这里的时候才会装载,而且let定义的name会覆盖var定义的name
    console.log('hi-2', name)
};
sayhi()
console.log(name);
复制代码


输出:


大马猴
console.log('hi-1', name)
                    ^
ReferenceError: Cannot access 'name' before initialization
复制代码


3.4、重复定义


var可以重复定义变量,这就导致了数据的冗余和代码不可读性提升。

目录
打赏
0
0
0
0
3
分享
相关文章
【JavaScript】深入理解 let、var 和 const
掌握这些关键字的使用可以提高代码的可读性和可维护性,避免潜在的变量提升和作用域问题。希望本文能帮助您更好地理解和应用 JavaScript 中的变量声明方式,编写出更高质量的代码。
65 20
通过array.some()实现权限检查、表单验证、库存管理、内容审查和数据处理;js数组元素检查的方法,some()的使用详解,array.some与array.every的区别(附实际应用代码)
array.some()可以用来权限检查、表单验证、库存管理、内容审查和数据处理等数据校验工作,核心在于利用其短路机制,速度更快,节约性能。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
通过array.every()实现数据验证、权限检查和一致性检查;js数组元素检查的方法,every()的使用详解,array.some与array.every的区别(附实际应用代码)
array.every()可以用来数据验证、权限检查、一致性检查等数据校验工作,核心在于利用其短路机制,速度更快,节约性能。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
this、self、window、top 在 JavaScript 中的区别深入研究
在 JavaScript 开发中,`this`、`self`、`window` 和 `top` 是四个常用的概念。`this` 指向当前执行上下文的对象,其值取决于函数调用方式;`self` 在全局作用域中等同于 `window`,常用于 Web Workers;`window` 代表浏览器窗口,是全局变量的容器;`top` 指向最顶层窗口,用于判断是否在框架中。理解这些概念有助于编写健壮的代码。
50 1
this、self、window、top 在 JavaScript 中的区别深入研究
ECMAScript 6(以下简称 ES6)的出现为 JavaScript 带来了许多新的特性和改进,其中 let 和 const 是两个非常重要的关键字。
ES6 引入了 `let` 和 `const` 关键字,为 JavaScript 的变量管理带来了革新。`let` 提供了块级作用域和暂存死区特性,避免变量污染,增强代码可读性和安全性;`const` 用于声明不可重新赋值的常量,但允许对象和数组的内部修改。两者在循环、函数内部及复杂项目中广泛应用,有助于实现不可变数据结构,提升代码质量。
57 5
js中的bind,call,apply方法的区别以及用法
JavaScript中,`bind`、`call`和`apply`均可改变函数的`this`指向并传递参数。其中,`bind`返回一个新函数,不立即执行;`call`和`apply`则立即执行,且`apply`的参数以数组形式传递。三者在改变`this`指向及传参上功能相似,但在执行时机和参数传递方式上有所区别。
60 1
JavaScript中的原型 保姆级文章一文搞懂
本文详细解析了JavaScript中的原型概念,从构造函数、原型对象、`__proto__`属性、`constructor`属性到原型链,层层递进地解释了JavaScript如何通过原型实现继承机制。适合初学者深入理解JS面向对象编程的核心原理。
60 1
JavaScript中的原型 保姆级文章一文搞懂
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
153 2
|
4月前
JS+CSS3文章内容背景黑白切换源码
JS+CSS3文章内容背景黑白切换源码是一款基于JS+CSS3制作的简单网页文章文字内容背景颜色黑白切换效果。
40 0
基于springboot+vue.js+uniapp的小区物流配送系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的小区物流配送系统附带文章源码部署视频讲解等
223 5

热门文章

最新文章