工作日常--浅谈ES6的let/const

本文介绍了ES5与ES6中变量申明的区别,包括var与let的不同之处,探讨了块级作用域的重要性,并解释了const命令的用法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在es5中平常工作中,我们声明变量的方式基本就是两种如下

var a = '';
b

以上的两种申明变量的方式在之前的ES5中都可以这么做。前者声明的变量a进行了初始化,默认情况下a是为空的字符串。b变量未给任何的前置申明,在前端面试中最喜欢问到的就是这个。其实这么写的话,该变量就是全局变量。在js的它以后都可以访问到它。

let

块级作用域

let命令是在ES6中新增的命令,用于申明变量。在某些情况下,基本等同于ES5中的var。但是你运行如下的代码。会发现神奇的地方。

{
  var a = 2;
  let b = 3;
}
console.log(a);  // 2
console.log(b);  // 报错

在上上面明明已经申明了,但是在打印b变量的时候还是会报错呢?因为在ES6中,let命令是将该变量锁定在该块内。在该块外部是无法访问该变量。
为什么需要块级作用域变量呢?看下面的例子

var temp = new Date();
function fun(){
 var temp = '字符串';
}
fun()
console.log(temp) // 字符串

如果没有块级作用域的情况下,会存在外部的变量被内部影响。

变量提升

let不像var那样会发生变量提升的现象。所以变量一定要在申明后使用,否则报错摘自阮一峰大神的ES6标准入门一书中,其实在现在我写的ES5中变量也是不能未申明使用的。

不允许重复申明

let不允许在同一个作用域内重复申明一个变量,如下代码是不被允许的

function fun(){
  let a = 1;
  var a = 2; // 报错
}

const

const与let唯一的区别就在于,该命令申明的变量是只读的,无法修改。如果修改则会报错。同时该命令申明的变量也是在该作用域内有效。

const array = [];
array.push('222') //报错
我vue项目启动的时候报如下错误如何解决: ERROR Failed to compile with 394 errors 14:21:17 These dependencies were not found: * core-js/modules/es6.array.fill in ./src/views/bus/track/js/turf.min.js * core-js/modules/es6.array.find in ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/components/Generator/components/InputTable/index.vue?vue&type=script&lang=js&, ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/components/Generator/index/RightComponents/Calculate.vue?vue&type=script&lang=js& and 4 others * core-js/modules/es6.array.find-index in ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/components/Ge nerator/components/InputTable/index.vue?vue&type=script&lang=js&, ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/components/Generator/index/Home.vue?vue&type=script&lang=js& and 7 others * core-js/modules/es6.array.from in ./src/utils/index.js * core-js/modules/es6.array.sort in ./src/components/bus-extents/map/geotool.js, ./src/mixins/generator/index.js and 8 others * core-js/modules/es6.function.name in ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/components/Gener ator/components/Upload/UploadImg.vue?vue&type=script&lang=js&, ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/components/Generator/index/DraggableItem.vue?vue&type=script&lang=js& and 43 others * core-js/modules/es6.map in ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/views/basic/dynamicModel/list/detail/index.vue?vue&type=script&lang=js&, ./src/views/bus/track/js/turf.min.js * core-js/modules/es6.math.sign in ./src/views/bus/track/js/turf.min.js * core-js/modules/es6.math.trunc in ./src/views/bus/track/js/turf.min.js * core-js/modules/es6.number.constructor in ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/components/ Generator/components/Calculate/index.vue?vue&type=script&lang=js&, ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/components/Generator/components/InputTable/index.vue?vue&type=script&lang=js& and 26 others * core-js/modules/es6.number.is-finite in ./src/views/bus/track/js/turf.min.js * core-js/modules/es6.number.is-integer in ./src/views/bus/track/js/turf.min.js * core-js/modules/es6.number.is-nan in ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/components/Generator/components/InputTable/index.vue?vue&type=script&lang=js&, ./src/components/Generator/utils/index.js and 1 other * core-js/modules/es6.number.parse-float in ./src/views/bus/track/js/turf.min.js * core-js/modules/es6.object.freeze in ./src/views/bus/track/js/turf.min.js * core-js/modules/es6.object.keys in ./src/main.js, ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/components/Generator/index/Home.vue?vue&type=script&lang=js& and 8 others * core-js/modules/es6.regexp.constructor in ./src/components/Generator/render/render.js, ./src/components/Generator/utils/index.js and 3 others * core-js/modules/es6.regexp.flags in ./src/views/bus/track/js/turf.min.js * core-js/modules/es6.regexp.match in ./src/utils/index.js, ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/views/bus/app/appDown.vue?vue&type=script&lang=js& and 1 other * core-js/modules/es6.regexp.replace in ./src/api/workFlow/workFlowForm.js, ./src/components/Generator/render/render.js and 34 others * core-js/modules/es6.regexp.search in ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/components/Heade rSearch/index.vue?vue&type=script&lang=js&, ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/components/JNPF-iconBox/index.vue?vue&type=script&lang=js& and 36 others * core-js/modules/es6.regexp.split in ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/components/Genera tor/components/Calculate/index.vue?vue&type=script&lang=js&, ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/components/Generator/index/RightPanel.vue?vue&type=script&lang=js& and 38 others * core-js/modules/es6.regexp.to-string in ./src/components/Generator/utils/index.js, ./src/filters/index.js and 16 others * core-js/modules/es6.set in ./src/utils/index.js, ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/views/permission/authorize/index.vue?vue&type=script&lang=js& * core-js/modules/es6.string.includes in ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/components/Col umnDesign/index.vue?vue&type=script&lang=js&, ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/components/Generator/components/InputTable/index.vue?vue&type=script&lang=js& and 14 others * core-js/modules/es6.string.iterator in ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/components/bus-extents/print/PrintView.vue?vue&type=script&lang=js&, ./src/utils/index.js and 5 others * core-js/modules/es6.symbol in ./src/views/bus/track/js/jquery-3.3.1.min.js * core-js/modules/es6.typed.float64-array in ./src/views/bus/track/js/turf.min.js * core-js/modules/es6.typed.int32-array in ./src/views/bus/track/js/turf.min.js * core-js/modules/es6.typed.int8-array in ./src/views/bus/track/js/turf.min.js * core-js/modules/es6.typed.uint32-array in ./src/views/bus/track/js/turf.min.js * core-js/modules/es7.array.includes in ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/components/Colu mnDesign/index.vue?vue&type=script&lang=js&, ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/components/Generator/components/InputTable/index.vue?vue&type=script&lang=js& and 17 others * core-js/modules/es7.string.pad-start in ./src/utils/index.js, ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/views/bus/askLeave/Detail.vue?vue&type=script&lang=js& and 6 others * core-js/modules/es7.symbol.async-iterator in ./src/views/bus/track/js/jquery-3.3.1.min.js * core-js/modules/web.dom.iterable in ./src/main.js, ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/components/ColumnDesign/index.vue?vue&type=script&lang=js& and 71 others To install them, you can run: npm install --save core-js/modules/es6.array.fill core-js/modules/es6.array.find core-js/modules/es6.array.find-index core-js/modules/es6.array.from core-js/modules/es6.array.sort core-js/modules/es6.function.name core-js/modules/es6.map core-js/modules/es6.math.sign core-js/modules/es6.math.trunc core-js/modules/es6.number.constructor core-js/modules/es6.number.is-finite core-js/modules/es6.number.is-integer core-js/modules/es6.number.is-nan core-js/mod ules/es6.number.parse-float core-js/modules/es6.object.freeze core-js/modules/es6.object.keys core-js/modules/es6.regexp.constructor core-js/modules/es6.regexp.flags core-js/modules/es6.regexp.match core-js/modules/es6.regexp.replace core-js/mo dules/es6.regexp.search core-js/modules/es6.regexp.split core-js/modules/es6.regexp.to-string core-js/modules/es6.set core-js/modules/es6.string.includes core-js/modules/es6.string.iterator core-js/modules/es6.symbol core-js/modules/es6.typed.f loat64-array core-js/modules/es6.typed.int32-array core-js/modules/es6.typed.int8-array core-js/modules/es6.typed.uint32-array core-js/modules/es7.array.includes core-js/modules/es7.string.pad-start core-js/modules/es7.symbol.async-iterator core-js/modules/web.dom.iterable Failed to resolve loader: core-js/modules/es6.function.name' in 'D:\Development\project\lh\linhai-boot-web\src\components\SimpleUploader You may need to install it.
05-15
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值