ES6 快速入门

快速了解ES6部分新特性。。。

let

ES6新增了let命令,用于声明变量。其用法类似var,但是声明的变量只在let命令所在的代码块内有效。

{
    let x = 10;
    var y = 20;
}

x  // ReferenceError: x is not defined
y  // 20

var声明变量存在变量提升。也就是在声明变量之前就可以使用该变量。

console.log(x)  // undefined,var声明变量之前可以使用该变量
var x = 10;

而let不会这样,let声明的变量不能在声明之前使用。

console.log(x)  // ReferenceError: x is not defined,let声明变量之前不可以使用该变量
let x = 10;

注意:

let不允许在相同的作用域内重复声明同一个变量。

比如:

function foo(){
    let x = 10;
    var x = 20;
}  // 报错

再比如:

function foo(){
    let y = 10;
    let y = 20;
}  // 报错

ES5中只有全局作用域和函数作用域,并没有块级作用域。

请看下面的示例:

var name = ‘Q1mi‘

function foo(){
    console.log(name)
    if (false){
        var name = ‘Bob‘
    }
}
foo()  // undefined

出现上述现象的原因就是在函数内部,由于变量提升导致内存的name变量覆盖了外层的name变量。

类似的情况还出现在 for循环的计数变量最后会泄露为全局变量。

for (var i=0;i<5;i++){
    console.log(‘哈哈‘);
}
console.log(i);  // 5

ES6中的let声明变量的方式实际上就为JavaScript新增了块级作用域。

var name = ‘Q1mi‘

function foo(){
    console.log(name)
    if (false){
        let name = ‘Bob‘
    }
}
foo()  // Q1mi

此时,在foo函数内容,外层代码块就不再受内层代码块的影响。所以类似for循环的计数变量我们最好都是用let来声明。

const

const用来声明常量。const声明变量必须立即初始化,并且其值不能再改变。

const声明常量的作用域与let相同,只在声明所在的块级作用域内有效。

例如:

const PI = 3.14;

全局对象的属性:

ES6规定:var命令和function命令声明的全局变量依旧是全局对象的属性;let命令、const命令和class命令声明的全局变量不属于全局对象的属性。

查看下面的示例代码:

var x = 10;
let y = 20;
window.x  // 10
window.y  // undefined

变量的解构赋值

ES6允许按照一定的模式,从数组或对象中提取值,对变量进行赋值,这种方式被称为解构赋值。

var [x, y, z] = [10, 20, 30]
x  // 10
y  // 20
z  // 30

对象的解构赋值:

var {x, y} = {x: 10, y: 20}
x  // 10
y  // 20

模板字符串

模板字符串(template string)是增强版的字符串,用反引号(`)标识。它可以当做普通字符串使用,也可以用来定义多行字符串,或者在字符串中嵌入变量。在模板字符串中嵌入变量,需要将变量名写入${}中。

var name = ‘Q1mi‘, age = 18;
`My name is ${name}, I’m ${age} years old.`

箭头函数

箭头函数中this指向会被固定化。这不是因为箭头函数内部有绑定this的机制。实际原因是箭头函数根本没有自己的this,导致内部的this就是外层代码块的this。

可以查看下面两段代码输出的区别:

var person = {
    name: ‘Q1mi‘,
    age:18,
    func:function(){
        console.log(this);
    }
}
person.func()  // person对象

var person = {
    name: ‘Q1mi‘,
    age:18,
    func:()=>{
        console.log(this);
    }
}
person.func()  // window对象

属性简洁表示法

ES6允许直接写入变量和函数作为对象的属性和方法。

function (x, y){
    return {x, y}
}

上面的写法等同于:

function(x, y){
    return {x: x, y: y}
}

对象的方法也可以使用简洁表示法:

var o = {
    method(){
        return “Hello!”;
    }
}

等同于:

var o = {
    method: function(){
        return “Hello!”;
    }
}

面向对象

ES5的构造对象的方式 使用构造函数来创造。构造函数唯一的不同是函数名首字母要大写。

function Person(name, age){
    // 点方法 set方法和get方法
    this.name = name;
    this.age = age;
    this.func = function(){
        ...
    }
}

// 给父级绑定方法
Person.prototype.showName = function(){
    console.log(this.name);
}

var p = new Person(‘q1mi’, 18);
console.log(p.name)
p.showName();

ES6 构造对象的方式:

class Person{
    constructor(name, age){
        this.name = name;
        this.age = age;
    }  // 不要加逗号!!!
    showName(){
        console.log(this.name);
    }
}

var p = new Person()

附:

有关ES6的其他新特性,推荐阅读:阮一峰的ECMAScript 6 入门

原文地址:https://www.cnblogs.com/liwenzhou/p/9249932.html

时间: 2024-07-30 10:01:33

ES6 快速入门的相关文章

Vue -- ES6 快速入门,Vue初识

一.ES6快速入门 let和const let ES6新增了let命令,用于声明变量.其用法类似var,但是声明的变量只在let命令所在的代码块内有效. { let x = 10; var y = 20; } x // ReferenceError: x is not defined y // 20 效果如下: var声明变量存在变量提升.也就是在声明变量之前就可以使用该变量. console.log(x) // undefined,var声明变量之前可以使用该变量 var x = 10; 刷新

es6快速入门

上次分享了es6开发环境的搭建,本次接着分享es6常用的特性. 1.变量声明let和const 我们都是知道在ES6以前,var关键字声明变量.无论声明在何处,都会被视为声明在函数的最顶部(不在函数内即在全局作用域的最顶部).这就是函数变量提升例如: function aa() { if(bool) { var test = 'hello man' } else { console.log(test) } } 以上的代码实际上是: function aa() { var test // 变量提升

微服务的入门级微框架Spring Boot快速入门

详情请交流  QQ  709639943 00.微服务的入门级微框架Spring Boot快速入门 00.基于java的微信公众号二次开发视频教程 00.leetcode 算法 面试 00.北风网 零基础到数据(大数据)分析专家-首席分析师 00.快速上手JMeter 00.Jmeter 00.2017年Java web开发工程师成长之路 00.R语言速成实战 00.R语言数据分析实战 00.Python+Django+Ansible Playbook自动化运维项目实战 00.Java深入微服务

elasticsearch系列二:索引详解(快速入门、索引管理、映射详解、索引别名)

一.快速入门 1. 查看集群的健康状况 http://localhost:9200/_cat http://localhost:9200/_cat/health?v 说明:v是用来要求在结果中返回表头 状态值说明 Green - everything is good (cluster is fully functional),即最佳状态Yellow - all data is available but some replicas are not yet allocated (cluster i

【JavaScript】快速入门

摘抄地址快速入门 No1: JavaScript严格区分大小写 No2: JavaScript不区分整数和浮点数,统一用Number表示 NaN表示Not a Number,当无法计算结果时用NaN表示 Infinity表示无限大,当数值超过了JavaScript的Number所能表示的最大值时,就表示为Infinity JavaScript允许对任意数据类型做比较 No3: 要特别注意相等运算符==.JavaScript在设计时,有两种比较运算符: 第一种是==比较,它会自动转换数据类型再比较

npm 与 package.json 快速入门教程

npm 与 package.json 快速入门教程 2017年08月02日 19:16:20 阅读数:33887 npm 是前端开发广泛使用的包管理工具,之前使用 Weex 时看了阮一峰前辈的文章了解了一些,这次结合官方文章总结一下,加深下理解吧! 读完本文你将了解: 什么是 npm? 安装 npm 更新 npm package.json 文件 package.json 如何创建 package.json 的内容 指定依赖的包 Semantic versioning(语义化版本规则) 安装 pa

doodoo.js快速入门教程

Doodoo.js -- 中文最佳实践Node.js Web快速开发框架.支持Koa.js, Express.js中间件,支持模块化,插件,钩子机制,可以直接在项目里使用 ES6/7(Generator Function, Class, Async & Await)等特性 https://www.doodooke.com 快速入门我们通过3步演示如何快速创建一个doodoo项目 第一步 # 创建doodoo-demo目录 mkdir doodoo-demo && cd doodoo

10 分钟,带你快速入门前端三大技术(HTML、CSS、JavaScript)

听到前端技术,不少朋友一定会感到有些陌生.但其实,前端,你每天都在接触. 你正在使用的APP,你正在浏览的网页,这些你能看到的界面,都属于前端. 而前端最重要的三大技术,HTML,CSS,JavaScript,则是每一个前端开发者必须具备的技能. 掌握这些技能,你可以快速地做出一个酷炫的APP界面或者一个简单大方的网站页面.因此,就让我们一起来快速学习一下这三门技术吧. 以下内容节选自课程<Vue.js 和 Node.js 构建内容发布系统>. 大家也可以点击课程链接,在实验楼提供的虚拟机环境

笔记:Spring Cloud Zuul 快速入门

Spring Cloud Zuul 实现了路由规则与实例的维护问题,通过 Spring Cloud Eureka 进行整合,将自身注册为 Eureka 服务治理下的应用,同时从 Eureka 中获取了所有其他微服务的实例信息,这样的设计非常巧妙的将服务治理体系中维护的实例信息利用起来,使得维护服务实例的工作交给了服务治理框架自动完成,而对路由规则的维护,默认会将通过以服务名作为 ContextPath 的方式来创建路由映射,也可以做一些特别的配置,对于签名校验.登录校验等在微服务架构中的冗余问题