let指示的用语
let是es6中的新闻稿两个表达式的指示,只在它新闻稿的标识符块中有效率,出了那个标识符块就会收起。也适于for循环式,在循环式中i的值只在循环式句子中施行,在外面取不出的。
var指示新闻稿的是两个全局的表达式,i是对准自上而下的表达式,只会输入最终的值。而let只在循环式句子块里头施行,每天循环式单厢再次新闻稿两个i的,因此每天循环式都能领到相关联的值。
for循环式的表达式是父返回值,和在循环式胃部let表述的表达式(子返回值)无此同两个返回值。
比如:
//1.在另一方面所处标识符块中有效率
{
let a = 1;
var b = 2;
}
console.log(b); // 2
console.log(a); // a is not defined
//2.在for循环式句子块中有效率
for(var i=0;i<10;i++) {
//…
}
console.log(i); // 10
for(let j=0;j<10;j++) {
//…
}
console.log(j); // j is not defined
var arr = [];
for(var a=0;a<10;a++) {
arr[a] = function () {
console.log(a);
}
}
console.log(a[4]); // 10
for(let b=0;b<10;b++) {
arr[b] = function () {
console.log(b);
}
}
console.log(b[4]); // 4
// 3.for循环的表达式和循环式胃部的表达式for(var i=0;i<10;i++) {
let i = fed;
console.log(i);
}
/*
* 结果是
* fed
* fed
* fed
*/
let指示不存在返回值提升
var指示是会发生返回值提升的,在新闻稿之前,是undefined,未新闻稿便有默认值了。而let表述的表达式必须在新闻稿后使用。
console.log(fa); // undefined
var fa = 1;
console.log(fb); // fb is not defined
let fb = 2;
let存在暂时性死区
“暂时性死区”(temporal dead zone,简称 TDZ)是指在ES6的规定中,如果区块中存在let和const指示的,这两个指示新闻稿的表达式就已经形成了封闭返回值。在此之前新闻稿的表达式,单厢收起。
比如:下面新闻稿了两个自上而下表达式,但是在块级返回值中let又新闻稿了两个表达式。
var food = apple;
if(typeof str == string) {
food = banana; // Uncaught ReferenceError: food is not defined
let food;
console.log(food); // undefined
food = orange;
console.log(food); // orange
}
注意:暂时性四区会有一些不好的地方。
typeof检测不安全
typeof x; // Uncaught ReferenceError: x is not definedlet x;
不允许重复新闻稿
简而言之,就是不允许在同一返回值内,新闻稿两个一样的表达式。
比如:
{
let a = 1;
var a = 2; // Uncaught SyntaxError: Identifier a has already been declared}
// 或者
{
let b = 1;
let b = 2; // Uncaught SyntaxError: Identifier b has already been declared}
注意:不能在函数参数内重复新闻稿参数,否则收起。
function wait(x,y) {
let x = 1; // Uncaught SyntaxError: Identifier x has already been declared let y = 2; // Uncaught SyntaxError: Identifier y has already been declared}
wait(3,5);
顶层对象
在ES6之前,顶级对象的属性和自上而下表达式是一致的,因此导致出现很多问题。
只有运行开才能捕捉到错误,没法一开始就检测出错误。顶层对象是随时随地可以读取和写入的,因此不利于模块化编程。window其实指的是游览器窗口,顶层对象有两个实体含义。因此es6改进了一点,就是let,const新闻稿的自上而下表达式不属于顶层对象的属性。
比如:
var a = 1;
let b = 2;
console.log(window.a); // 1
console.log(window.b); // undefined
学以致用let指示
古语有云:学了就用处处行,不学不用等于零。因此我写了两个关于let的小例子。
这是两个选项卡的案例,在之前,我们还要表述btns[i].index = i,而现在用let指示就方便多了。
.tab {
width: 300px;
height: 30px;
border: 1px solid #fff;
}
.tab > span {
float: left;
display: block;
width: 98px;
height: 28px;
line-height: 28px;
text-align: center;
border: 1px solid #aaa;
cursor: pointer;
}
span.active {
color: #fff;
background-color: #f00;
border: 1px solid #f00;
}
.content, .content > p {
width: 300px;
height: 300px;
}
.content > p {
display: none;
border: 1px solid #aaa;
}
p.active {
display: block;
}
<div class=“tab”>
<span class=“active”>1</span>
<span>2</span>
<span>3</span>
</div>
<div class=“content”>
<p class=“active”>1的内容</p>
<p>2的内容</p>
<p>3的内容</p>
</div>
let btns = document.querySelectorAll(.tab span);
let contents = document.querySelectorAll(.content p);
for (let i = 0; i < btns.length; i++) {
btns[i].onclick = function() {
for (let j = 0; j < btns.length; j++) {
btns[j].className = ;
contents[j].className = ;
}
this.className = active;
contents[i].className = active;
}
}
写在最终
上面就是一些介绍如何正确的使用let指示,在实践中用起来吧。
欢猿七笔记