let是ES6新增的,它主要是弥补var的缺陷,你也能够把let看作var的升级版。下面我就来详细讲讲var和let的区别javascript
相同点:css
var和let都有函数级做用域html
不一样点:java
(1)var是全局做用域,let不是闭包
var 和 let 声明的变量在全局做用域中被定义时,二者很是类似。可是,被let声明的变量不会做为全局对象window的属性,而被var声明的变量却能够函数
let a = 'aaa; var b = 'bbb'; console.log(window.a); // undefined console.log(window.b); //'bbb'
(2)var没有块级做用域,let有快级做用域spa
let有块级做用域,而var没有块级做用域,这是两者最明显的区别。例如:3d
var func; if(1 == 1){ var name = "LHS" func = function(){ console.log(name) } } name = "ljq"; func();//输出的:ljq
通常状况咱们都但愿把块级内的与块级内数据区分,但var没有块级做用域,只有函数做用域code
若是你们还不理解,我再举例子:htm
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>闭包</title> <style type="text/css"> div { width: 100px; height: 100px; background: lightgreen; float: left; margin: 20px; font: 30px/100px "microsoft yahei"; text-align: center; } </style> </head> <body> <div>a</div> <div>b</div> <div>c</div> <div>d</div> <div>e</div> <div>f</div> <div>g</div> <div>h</div> <div>i</div> <div>j</div> </body> <script type="text/javascript"> var divs=document.getElementsByTagName("div"); for (var i=0;i<divs.length;i++) { divs[i].onclick=function(){ alert(i);//都是输出:10 } } </script> </html>
运行结果,点击输出都是10
以上问题就是var没有块级做用域,咱们能够把函数做用域代替了块级做用域,用闭包解决问题:
var divs=document.getElementsByTagName("div"); for (var i=0;i<divs.length;i++) { (function(i){ divs[i].onclick=function(){ alert(i); } })(i) }
闭包写起来有点麻烦,但使用let的话就能够一步到位:
var divs=document.getElementsByTagName("div"); for (let i=0;i<divs.length;i++) { divs[i].onclick=function(){ alert(i); } }
结果跟使用闭包同样,但比闭包简单
(3)var属于ES5规范,let属于ES6规范