现在就可以使用的5个 ES6 特性

这篇文章介绍了5个 ES6 特性,使你的 JavaScript 代码变的更好。不用说,我们大多数前端开发工程师非常关注 JavaScript 的性能和特性,这就是为什么 ES6 对于我们来说是如此令人兴奋。

ES6的变化是巨大的,是令人兴奋的,也有令人困惑的地方。在本文中,我将介绍5个 ES6 的新特性,您可以立即使用它们来增强你的 JavaScript代码,以及哪些特性不建议使用。 继续阅读

ES6中块级作用域及变量声明let

ES6之前JavaScript没有块级作用域,它使用var声明变量,以function来划分作用域,大括号“{}” 却限定不了var的作用域,用var声明的变量具有变量提升(declaration hoisting)的效果。ES6新增加了一个let,可以在{}, iffor里声明。用法同var,但作用域限定在块级,let声明的变量不存在变量提升。

例1: 块级作用域 if

function test(flag) {
    if (flag) {
        var a = 'js'
    } 
    // 这里也可以访问 a
}

变量a在if块里声明的,但在else块和if外都可以访问到val,把var换成let后:

function test(flag) {
    if (flag) {
        let a = 'js'
    } 
    // 这里也访问不到 a
}

继续阅读