浅谈JS中var,let和const的区别
作者:??桃子蘸酱? 发布时间:2024-05-09 15:07:16
标签:JS,var,let,const
区别1
let
和var
用来声明变量,const
用来声明常量。
变量就是赋值后可以改变它的值,常量就是赋值后就不能改变它的值。
当声明为对象时,可以直接修改对象内的属性值
const age = 26;
age = 36; // TypeError: 给常量赋值
// const声明的作用域也是块
const name = 'Matt';
if (true) {
const name = 'Nicholas';
}
console.log(name); // Matt
区别2
const
不允许只声明不赋值,一旦声明就必须赋值
const num; // 错误
const num = 1; //正确
区别3
var
是函数作用域,let
和const
是块级作用域。
花括号{}
就是块级作用域,函数作用域就是函数里面的内容。
{
let num = 4;
}
console.log(num);// num is not defined
{
var num = 4;
}
console.log(num); // 4
区别4
var
有提升的功能,let
和const
没有
// 片段A
console.log(a); //undefined
var a = 4;
// 片段B
console.log(b); //b is not defined
let b = 4;
片段A
在代码预编译时,javaScript引擎会自动将所有代码里面的var
关键字声明的语句都会提升到当前作用域的顶端,如下:
var a;
console.log(a); //undefined
a = 4;
区别5
在最外层的作用域,也就是全局作用域,用var
声明的变量,会作为window
的一个属性;而用let
和const
声明的变量或常量,并不会作为window
的属性
var a = 4;
function foo(){
/*
这里的this采用默认的规则,与window进行了绑定,所以实际上访问的是window.a
*/
console.log(this.a);// 4
}
foo()
let a = 4;
function foo(){
/*
在这种情况下,this.a 访问的是window.a,但是let定义的变量,并不会作为window的属性,所以访问不到
*/
console.log(this.a);// undefined
}
foo()
区别6
let
,const
不允许同一个块作用域中出现冗余声明(重复声明),而var
可以
var name;
var name; // 可以
let age;
let age; // SyntaxError;标识符age已经声明过了
const name = 'Matt';
const name = 'Nicholas'; // SyntaxError
区别7
变量渗透问题
// for循环中var定义的迭代变量会渗透到循环体外部
for (var i = 0; i < 5; ++i) {
// 循环逻辑
}
console.log(i); // 5
// 改成使用let之后,这个问题就消失了,因为迭代变量的作用域仅限于for循环块内部
for (let i = 0; i < 5; ++i) {
// 循环逻辑
}
console.log(i); // ReferenceError: i没有定义
来源:https://juejin.cn/post/7118643185328324644


猜你喜欢
- 本文给大家分享的是查看MySQL连接的root密码的方法,下面话不多说来来看正文:1.首先我们进到MySQL的bin目录下➜ cd /usr
- JS如何从一个数组中随机取出一个元素或者几个元素。假如数组为var items = ['1','2',
- 为了保证程序的健壮性与容错性,即在遇到错误时候程序不会崩溃,我们需要对异常进行处理,1.if进行处理,在错误发生之前进行预防如果错误发生的条
- CSV(Comma-Separated Values)即逗号分隔值,一种以逗号分隔按行存储的文本文件,所有的值都表现为字符串类型(注意:数字
- 一、问题的引入opencv在图像处理方面有着非常强大的功能,当我们需要使用opencv进行一些图像的矫正工作时,我们通常需要找到原图的一些关
- QueryCache(下面简称QC)是根据SQL语句来cache的。一个SQL查询如果以select开头,那么MySQL服务器将尝试对其使
- 这个例子可作为一个模式,在你需要的时候套用。<!DOCTYPE HTML PUBLIC &q
- 这里介绍一个nii文件保存为png格式的方法。这篇文章是介绍多个nii文件保存为png格式的方法:https://www.jb51.net/
- 一、通用爬虫通用网络爬虫是搜索引擎抓取系统(Baidu、Google、Sogou等)的一个重要组成部分。主要目的是将互联网上的网页下载到本地
- 阅读上一篇:交互设计模式(二)-Pagination(分页,标记页数) Tagging(标签)问题摘要用户往往想通过流行或最详尽的主题来浏览
- python封装利用begin end执行多条sql因为业务需求,优化模型运行时间。考虑到sql语句每一次执行都要建立连接,查询,获取数据耗
- 本文实例为大家分享了python爬取微信公众号文章的具体代码,供大家参考,具体内容如下该方法是依赖于urllib2库来完成的,首先你需要安装
- 可能许多同学对SQL Server的备份和还原有一些了解,也可能经常使用备份和还原功能,我相信除DBA之外我们大部分开发员队伍对备份和还原只
- 循环使用 else 语句在 python 中,for … else 表示这样的意思,for 中的语句和普通的没有区别,else 中的语句会在
- 在移动社交时代,微信已经成为我们生活不可或缺的一部分。2017年的《微信数据报告》中显示:每天有380亿条消息从微信上发出,其中6亿条是语音
- [sql] -- ===================【创建存储过程】===================== USE [Message
- 1、django应用Celerydjango框架请求/响应的过程是同步的,框架本身无法实现异步响应。但是我们在项目过程中会经常会遇到一些耗时
- wed的打印方法具我自己懂得知道的有: 1、JQuery插件Jqprint实现 2、JQery打印插件PrintArea实现网页打印 3、C
- 支付宝或者微信支付导出的收款二维码,除了二维码部分,还有很大一块背景图案,例如下面就是微信支付的收款二维码:有时候我们仅仅只想要图片中间的方
- 技术背景在一些对python开源库代码的安全扫描中,我们有可能需要分析库中所使用到的函数是否会对代码的执行环境造成一些非预期的影响。典型的例