es6之let命令

2023-05-30 0 581

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指示,在实践中用起来吧。

猿七笔记

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务