快速浏览 ES2015、ES2016、ES2017、ES2018 及以后的 JavaScript 新特性

常用

块范围

Let

function fn () {let x = 0if (true) {let x = 1 // 只在这个`if`里面}
}

Const

const a = 1

let 是新的 var。 常量(const) 就像 let 一样工作,但不能重新分配。
请参阅:Let 和 const

反引号字符串

插值

const message = `Hello ${name}`

多行字符串

const str = `
hello
world
`

模板和多行字符串。
请参阅:模板字符串

二进制和八进制文字

let bin = 0b1010010
let oct = 0o755

请参阅:二进制和八进制文字

指数运算符

const byte = 2 ** 8
// 同: Math.pow(2, 8)

新方法

新的字符串方法

"hello".repeat(3)
"hello".includes("ll")
"hello".startsWith("he")
"hello".padStart(8) // "   hello"
"hello".padEnd(8) // "hello   "
"hello".padEnd(8, '!') // hello!!!
"\u1E9B\u0323".normalize("NFC")

新的数字方法

Number.EPSILON
Number.isInteger(Infinity) // false
Number.isNaN("NaN") // false

新的 Math 方法

Math.acosh(3) // 1.762747174039086
Math.hypot(3, 4) // 5
Math.imul(Math.pow(2, 32) - 1, Math.pow(2, 32) - 2) // 2

新的 Array 方法

// 返回一个真实的数组
Array.from(document.querySelectorAll("*"))
// 类似于 new Array(...),但没有特殊的单参数行为
Array.of(1, 2, 3)

请参阅: 新方法

class Circle extends Shape {

构造函数

  constructor (radius) {this.radius = radius}

方法

  getArea () {return Math.PI * 2 * this.radius}

调用超类方法

  expand (n) {return super.expand(n) * Math.PI}

静态方法

  static createFromDiameter(diameter) {return new Circle(diameter / 2)}
}

原型的语法糖。
请参阅: 类

Promises

做出承诺

new Promise((resolve, reject) => {if (ok) { resolve(result) }else { reject(error) }
})

用于异步编程。
请参阅:Promises

使用 Promises

promise.then((result) => { ··· }).catch((error) => { ··· })

在 finally 中使用 Promise

promise.then((result) => { ··· }).catch((error) => { ··· }).finally(() => {/* 独立于成功/错误的逻辑 */})

当承诺被履行或被拒绝时,处理程序被调用

Promise 函数

Promise.all(···)
Promise.race(···)
Promise.reject(···)
Promise.resolve(···)

Async-await

async function run () {const user = await getUser()const tweets = await getTweets(user)return [user, tweets]
}

async 函数是使用函数的另一种方式。
请参阅:异步函数

解构 Destructuring

解构赋值

Arrays

const [first, last] = ['Nikola', 'Tesla']

Objects

let {title, author} = {title: 'The Silkworm',author: 'R. Galbraith'
}

支持匹配数组和对象。
请参阅:解构

默认值

const scores = [22, 33]
const [math = 50, sci = 50, arts = 50] = scores

// Result:
// math === 22, sci === 33, arts === 50

可以在解构数组或对象时分配默认值

函数参数

function greet({ name, greeting }) {console.log(`${greeting}, ${name}!`)
}

greet({ name: 'Larry', greeting: 'Ahoy' })

对象和数组的解构也可以在函数参数中完成

默认值

function greet({ name = 'Rauno' } = {}) {console.log(`Hi ${name}!`);
}

greet() // Hi Rauno!
greet({ name: 'Larry' }) // Hi Larry!

重新分配键

function printCoordinates({ left: x, top: y }) {console.log(`x: ${x}, y: ${y}`)
}

printCoordinates({ left: 25, top: 90 })

此示例将 x 分配给 left 键的值

循环

for (let {title, artist} of songs) {···
}

赋值表达式也在循环中工作

对象解构

const { id, ...detail } = song;

使用 rest(...) 运算符单独提取一些键和对象中的剩余键

扩展运算符 Spread

对象扩展

与对象扩展

const options = {...defaults,visible: true
}

没有对象扩展

const options = Object.assign({}, defaults,{ visible: true })

对象扩展运算符允许您从其他对象构建新对象。
请参阅:对象传播

数组扩展

具有数组扩展

const users = [...admins,...editors,'rstacruz'
]

没有数组扩展

const users = admins.concat(editors).concat([ 'rstacruz' ])

扩展运算符允许您以相同的方式构建新数组。
请参阅:扩展运算符

函数 Functions

函数参数

默认参数

function greet (name = 'Jerry') {return `Hello ${name}`
}

Rest 参数

function fn(x, ...y) {// y 是一个数组return x * y.length
}

扩展

fn(...[1, 2, 3])
// 与 fn(1, 2, 3) 相同

Default(默认), rest, spread(扩展)。
请参阅:函数参数

箭头函数

箭头函数

setTimeout(() => {···
})

带参数

readFile('text.txt', (err, data) => {...
})

隐式返回

arr.map(n => n*2)
// 没有花括号 = 隐式返回
// 同: arr.map(function (n) { return n*2 })
arr.map(n => ({result: n*2
}))
// 隐式返回对象需要在对象周围加上括号

类似函数,但保留了 this
请参阅:箭头函数

参数设置默认值

function log(x, y = 'World') {console.log(x, y);
}log('Hello')          // Hello World
log('Hello', 'China') // Hello China
log('Hello', '')      // Hello

与解构赋值默认值结合使用

function foo({x, y = 5} = {}) {console.log(x, y);
}foo() // undefined 5

name 属性

function foo() {}
foo.name // "foo"

Objects

速记语法

module.exports = { hello, bye }

同下:

module.exports = {hello: hello, bye: bye
}

请参阅:对象字面量增强

方法

const App = {start () {console.log('running')}
}
// 同: App = { start: function () {···} }

请参阅:对象文字增强

Getters and setters

const App = {get closed () {return this.status === 'closed'},set closed (value) {this.status = value ? 'closed' : 'open'}
}

请参阅:对象字面量增强

计算属性名称

let event = 'click'
let handlers = {[`on${event}`]: true
}
// 同: handlers = { 'onclick': true }

请参阅:对象字面量增强

提取值

const fatherJS = { age: 57, name: "张三" }
Object.values(fatherJS)
// [57, "张三"]
Object.entries(fatherJS)
// [["age", 57], ["name", "张三"]]

Modules 模块

Imports 导入

import 'helpers'
// 又名: require('···')

import Express from 'express'
// 又名: const Express = require('···').default || require('···')

import { indent } from 'helpers'
// 又名: const indent = require('···').indent

import * as Helpers from 'helpers'
// 又名: const Helpers = require('···')

import { indentSpaces as indent } from 'helpers'
// 又名: const indent = require('···').indentSpaces

import 是新的 require()
请参阅:Module imports

Exports 导出

export default function () { ··· }
// 又名: module.exports.default = ···

export function mymethod () { ··· }
// 又名: module.exports.mymethod = ···

export const pi = 3.14159
// 又名: module.exports.pi = ···

const firstName = 'Michael';
const lastName = 'Jackson';
const year = 1958;
export { firstName, lastName, year };

export * from "lib/math";

export 是新的module.exports
请参阅:Module exports

as 关键字重命名

import {lastName as surname // 导入重命名
} from './profile.js';function v1() { ... }
function v2() { ... }export { v1 as default };
// 等同于 export default v1;export {v1 as streamV1,           // 导出重命名v2 as streamV2,           // 导出重命名v2 as streamLatestVersion // 导出重命名
};

动态加载模块

button.addEventListener('click', event => {import('./dialogBox.js').then(dialogBox => {dialogBox.open();}).catch(error => {/* Error handling */})
});

ES2020提案 引入 import() 函数

import() 允许模块路径动态生成

const main = document.querySelector('main')import(`./modules/${someVariable}.js`).then(module => {module.loadPageInto(main);}).catch(err => {main.textContent = err.message;});

import.meta

ES2020 为 import 命令添加了一个元属性 import.meta,返回当前模块的元信息

new URL('data.txt', import.meta.url)

Node.js 环境中,import.meta.url返回的总是本地路径,即 file:URL 协议的字符串,比如 file:///home/user/foo.js

Generators

Generator 函数

function* idMaker () {let id = 0while (true) { yield id++ }
}

let gen = idMaker()
gen.next().value  // → 0
gen.next().value  // → 1
gen.next().value  // → 2

情况很复杂。
请参阅:Generators

For…of + 迭代器(iterator)

let fibonacci = {[Symbol.iterator]() {let pre = 0, cur = 1;return {next() {[pre, cur] = [cur, pre + cur];return { done: false, value: cur }}}}
}for (var n of fibonacci) {// 在 1000 处截断序列if (n > 1000) break;console.log(n);
}

用于迭代生成器和数组。
请参阅:For…of iteration

与 Iterator 接口的关系

var gen = {};
gen[Symbol.iterator] = function* () {yield 1;yield 2;yield 3;
};[...gen] // => [1, 2, 3]

Generator 函数赋值给 Symbol.iterator 属性,从而使得 gen 对象具有了 Iterator 接口,可以被 ... 运算符遍历了

Symbol.iterator 属性

function* gen() { /* some code */ }
var g = gen();g[Symbol.iterator]() === g // true

gen 是一个 Generator 函数,调用它会生成一个遍历器对象g。它的 Symbol.iterator 属性,也是一个遍历器对象生成函数,执行后返回它自己

另见

  • Learn ES2015 (babeljs.io)
  • ECMAScript 6 功能概述 (github.com)
  • ECMAScript 6 入门教程 (阮一峰) (ruanyifeng.com)

ES2015+ 备忘清单相关推荐

  1. 机器学习项目的备忘清单!

    ↑↑↑关注后"星标"Datawhale 每日干货 & 每月组队学习,不错过 Datawhale干货 作者:Harshit Tyagi,编译:机器之心 机器学习项目中含有众多 ...

  2. git-flow 流程 备忘清单

    关于 git-flow 是一个 git 扩展集,按 Vincent Driessen 的分支模型提供高层次的库操作. 查看详情 ★ ★ ★ 这个备忘清单展示了 git-flow 的基本操作和效果. ★ ...

  3. MATLAB 备忘清单_开发速查表分享

    MATLAB 备忘清单 MATLAB是美国MathWorks公司出品的商业数学软件,用于数据分析.无线通信.深度学习.图像处理与计算机视觉.信号处理.量化金融与风险管理.机器人,控制系统等领域. MA ...

  4. Adobe Photoshop 键盘快捷键 备忘清单

    Adobe Photoshop 键盘快捷键 备忘清单 PS简介 PS发展 PS 快捷键 283个 PS简介 Adobe Photoshop,简称"PS",是由Adobe Syste ...

  5. 《程序员修炼之道》备忘清单

    1.关心你的技艺 如果你不在乎能否开发出漂亮的软件,你又何必要耗费生命去开发软件呢? 2.思考!你的工作 关掉自动驾驶仪,接管操作.不断的批评和评估你的工作 3.提供各种选择,不要找蹩脚的接借口 要提 ...

  6. 《现代命令行工具指南》8. 备忘清单:让常用命令能够信手拈来 - navi

    ​好工具就是生产力,这是专栏<现代命令行工具指南>精讲的第 8 个命令行工具,欢迎品鉴. 命令用完就忘怎么办?命令太复杂记不住怎么办? 用备忘录啊,把常用的.复杂的.记不住的命令记下来,以 ...

  7. 准备度假了吗?比防晒霜更重要的备忘清单

    作者:趋势科技资深分析师 RikFerguson 分享照片.利用GPS 签到,或是叙述自己会用多长时间享受阳光等细节,这些行为就好像在你家房顶上架了一个超大的霓虹灯,亮着"空房"的 ...

  8. js数组获取index_通过事例重温一下 JS 中 常见的15 种数组操作(备忘清单),收藏...

    数组是 JS 中广泛使用的数据结构.数组对象提供了大量有用的方法,如array. forEach().array.map()等来操作数组. 在实战中,我经常对数组可能的操作和相应采用哪个更好的方法不知 ...

  9. js数组获取index_通过事例重温一下常见的 JS 中 15 种数组操作(备忘清单)

    作者:Dmitri Pavlutin 译者:前端小智 来源:dmitripavlutin.com 最近几天,公众号无套路抽奖现金 200,参与方式如下: 存而不论是一种对舆论场合的改善?(每月一次抽大 ...

最新文章

  1. 版电力系统故障录波_电力系统中的变电运维技术匹配专业中的应用
  2. SQL操作语句中的注意点
  3. React Bind Handle的思考
  4. python 美化输出 错误 警告等信息_OpenCV抑制、隐藏或禁用输出到屏幕的错误或警告消息...
  5. apk私钥_使用source/build/target/product/security/中的密钥将apk签署为系统
  6. 老男孩python全栈开发视频教程_老男孩Python全栈开发(92天全)视频教程 自学笔记08...
  7. Python调Windows的资源管理器打开指定目录
  8. 某系统有6台输出设备 有多个进程均需要使用2台_双11的秒杀系统,是如何设计的?...
  9. Kali Linux 安全渗透教程lt;第三更gt;1.2 安全渗透所需工具
  10. 【STM32】【STM32CubeMX】STM32CubeMX的使用之五:定时器时基配置及其中断
  11. iOS-UITextField中给placeholder动态设置颜色的四种方法
  12. ExtJs页面布局总结(转载)
  13. JS获取填报扩展单元格控件的值
  14. 网站服务器 80端口吗,你的服务器打开IIS80端口了吗?
  15. 方正璞华“劳动人事法律自助咨询服务平台”在武汉武昌区投入使用!
  16. 计算机的外围设备找不到,bluetooth外围设备,教您bluetooth外围设备找不到驱动程序怎么解决...
  17. 2021.1.15——星露谷作物计算器的小改进
  18. 选择工业相机需要知道的50个问题
  19. 步进电机工作原理与编程
  20. 139邮箱无法连接服务器,手机号登录邮箱,为什么总是连接不到服务器?

热门文章

  1. R语言小代码6(股票数据分析)
  2. 深度学习:神经网络中的激活函数
  3. GASSHOW:野田洋次郎为东日本大地震丧生的罹难者所创的镇魂曲。
  4. MyEclipse 9.0 正式版发布新闻 下载
  5. java海报_使用java画一张海报
  6. php ical 时区_如何将iCal或.ICS文件导入Google日历
  7. Rk3566 Rk3326s Android11去掉谷歌所有应用套件
  8. python语音验证码识别_python验证码自动识别
  9. 富兰克林的13条自律法则
  10. 《HelloGitHub》第 68 期