说起ES6应该也不是很新的东西了毕竟ES9都出来了,但是我们发现,在前端开发过程中ES6运用的并不多,可能大家有的也不理解为什么有ES6这个东西。
所以最近可能会写一个ES6的专题,我们来好好学习下ES6的一些核心及很有用的功能
今天我们来说说ES6的变量命名规范
let
let 大家也不陌生了 ,在平常也用的比较多,可以说let可以完全取代var
但是它为什么可以取代var呢,或者说var有什么不好呢?
1、首先我们要指导 var是函数及作用域let是块级作用域
看代码(代码功能:点击按钮弹出对应下标)
![e96cf037df901e2119bee93c499bb7e1.png](https://i-blog.csdnimg.cn/blog_migrate/e5412aea7a65428fa84da7b86d46eb68.jpeg)
点击按钮弹出对应下标 var
我们会发现弹出来的一直是3
这是因为用var申明的变量不是块级作用域,一个for循环下来i的值就变成了3(这时候如果要想实现功能只能用闭包来解决了)
当我们把var改成let就可以实现我们想要的功能了
![2fc5e9bb87d77371bc8b038eb2fbfcfe.png](https://i-blog.csdnimg.cn/blog_migrate/dcc7cc513de6ca22d7f2ff2a09c90918.jpeg)
点击按钮弹出对应下标 let
2、var 可以重复声明,let不可以
有人说可以重复声明不是很好吗,其实如果变量可以重复声明的话会出现很多隐患和弊端,对于一个严格的程序语言来说,变量是不可以在重复命名
![b7092426ed4532c7242df0ac8d54e64b.png](https://i-blog.csdnimg.cn/blog_migrate/456c7d1c96a0531422900494d38f201d.jpeg)
换成let
![29ab417a9fdb3a9350ce3d43010c9633.png](https://i-blog.csdnimg.cn/blog_migrate/a0880d81de3deba195e829f6f61e36f9.jpeg)
会报一个错,告诉我们a已经被申明过,不能再次声明
![d8761dae039318da3f04560582a64406.png](https://i-blog.csdnimg.cn/blog_migrate/5b299ad3bfc57149908800510407ac92.jpeg)
let 和 const
const的很多属性和let一样,但是conts命名的是常量,更有征对性
一旦用conts命名就说明这个变量是不可以更改的否则代码就会报错
奇淫技巧
并不是所有用conts声明的都不可以修改比如说对象
![678b954d24410de00fb7da8398ea2e61.png](https://i-blog.csdnimg.cn/blog_migrate/d3ed3f1e74ce1a8aa8c1106aceefa75d.jpeg)
想知道原因的可以自行百度或私信我哦!
![d6f8f7a7695c034ba174ea0aaf0d427d.png](https://i-blog.csdnimg.cn/blog_migrate/7d696564105d05e97b5ab1edfb5906ce.jpeg)