DDR爱好者之家 Design By 杰米
最近看国外的前端代码时,发现ES6的新特性已经相当普及,尤其是 let,应用非常普遍
虽然 let 的用法与 var 相同,但不管是语法语义上,还是性能上,都提升了很多,下面就从这两方面对比一下
语法
for ( var i=0; i<2; i++){ console.log( 'outer i: ' + i); for ( var i=0; i<2; i++){ console.log( 'inner i: ' +i); } }
这是一个常见的嵌套循环,都定义了变量 i 来计数,执行结果如下:
outer i: 0
inner i: 0
inner i: 1
可以看到,外层循环被打断了,因为 i 的值被内层循环修改了,通常的解决方法是内层循环中使用其他的变量,但有可能一不小心就出错了
现在把 var 换成 let
for ( let i=0; i<2; i++){ console.log( 'outer i: ' + i); for ( let i=0; i<2; i++){ console.log( 'inner i: ' +i); } }
输出结果为:
outer i: 0
inner i: 0
inner i: 1outer i: 1
inner i: 0
inner i: 1
很正常,内外层没有任何影响,因为 let 使变量的作用域只在自己所在块儿之内
示例2
console.log(a); var a = 'hi' ;
输出结果为 undefined,执行 log(a) 是在声明变量之前,为什么没有报错?因为这两行代码实际的效果是:
var a;console.log(a); a = 'hi';
在解析JS代码时,会把变量的声明提示到开始位置,这个方式也比较让人迷惑
改用 let 后,就没有这个问题了,会直接报错
console.log(a); // Uncaught ReferenceError: a is not definedlet a = 'hi' ;
性能做一个简单的测试
var start = + new Date(); for ( var i = 0;i<1000000;i++){ var num = 123; var str = 'abc' ; var obj = {key: 'value' }; var arr = [ 'bill' , 'dell' ]; } var end = + new Date(); console.log(end - start);
在Firefox下的执行结果平均为 53ms
改为 let
'use strict' var start = + new Date(); for ( var i = 0;i<1000000;i++){ let num = 123; let str = 'abc' ; let obj = {key: 'value' }; let arr = [ 'bill' , 'dell' ]; } var end = + new Date(); console.log(end - start);
结果平均为 5ms ,提速很明显
以上所述是小编给大家介绍的JavaScript6 let 新语法优势,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米
暂无评论...
更新日志
2024年11月29日
2024年11月29日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]