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

常用

块范围

Let

{2,4}
1
2
3
4
5
6
function fn () {
let x = 0
if (true) {
let x = 1 // 只在这个`if`里面
}
}

Const

1
const a = 1

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

反引号字符串

插值

1
const message = `Hello ${name}`

多行字符串

1
2
3
4
const str = `
hello
world
`

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

二进制和八进制文字

1
2
let bin = 0b1010010
let oct = 0o755

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

指数运算符

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

新方法

新的字符串方法

1
2
3
4
5
6
7
"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")

新的数字方法

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

新的 Math 方法

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

新的 Array 方法

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

请参阅: 新方法

1
class Circle extends Shape {

构造函数

{1}
1
2
3
constructor (radius) {
this.radius = radius
}

方法

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

调用超类方法

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

静态方法

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

原型的语法糖。
请参阅:

私有类

javascript 默认字段是公共的(public),如果需要注明私有,可以使用(#

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
class Dog {
#name;
constructor(name) {
this.#name = name;
}
printName() {
//只能在类内部调用私有字段
console.log(`你的名字是${this.#name}`)
}
}

const dog = new Dog("putty")
//console.log(this.#name)
//Private identifiers are not allowed outside class bodies.
dog.printName()

静态私有类

1
2
3
4
5
6
7
8
class ClassWithPrivate {
static #privateStaticField;
static #privateStaticFieldWithInitializer = 42;

static #privateStaticMethod() {
// …
}
}

Promises

做出承诺

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

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

使用 Promises

{2,3}
1
2
3
promise
.then((result) => { ··· })
.catch((error) => { ··· })

在 finally 中使用 Promise

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

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

Promise 函数

1
2
3
4
Promise.all(···)
Promise.race(···)
Promise.reject(···)
Promise.resolve(···)

Async-await

{2,3}
1
2
3
4
5
async function run () {
const user = await getUser()
const tweets = await getTweets(user)
return [user, tweets]
}

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

解构 Destructuring

解构赋值

Arrays

{1}
1
const [first, last] = ['Nikola', 'Tesla']

Objects

{1}
1
2
3
4
let {title, author} = {
title: 'The Silkworm',
author: 'R. Galbraith'
}

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

默认值

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

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

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

函数参数

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

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

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

默认值

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

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

重新分配键

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

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

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

循环

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

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

对象解构

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

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

扩展运算符 Spread

对象扩展

与对象扩展

{2}
1
2
3
4
const options = {
...defaults,
visible: true
}

没有对象扩展

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

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

数组扩展

具有数组扩展

{2,3}
1
2
3
4
5
const users = [
...admins,
...editors,
'rstacruz'
]

没有数组扩展

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

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

函数 Functions

函数参数

默认参数

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

Rest 参数

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

扩展

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

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

箭头函数

箭头函数

{1}
1
2
3
setTimeout(() => {
···
})

带参数

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

隐式返回

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

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

参数设置默认值

1
2
3
4
5
6
7
function log(x, y = 'World') {
console.log(x, y);
}

log('Hello') // Hello World
log('Hello', 'China') // Hello China
log('Hello', '') // Hello

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

1
2
3
4
5
function foo({x, y = 5} = {}) {
console.log(x, y);
}

foo() // undefined 5

name 属性

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

length 属性

1
2
function foo(a, b){}
foo.length // 2

Objects

速记语法

1
module.exports = { hello, bye }

同下:

1
2
3
module.exports = {
hello: hello, bye: bye
}

请参阅:对象字面量增强

方法

{2}
1
2
3
4
5
6
const App = {
start () {
console.log('running')
}
}
// 同: App = { start: function () {···} }

请参阅:对象文字增强

Getters and setters

{2,5}
1
2
3
4
5
6
7
8
const App = {
get closed () {
return this.status === 'closed'
},
set closed (value) {
this.status = value ? 'closed' : 'open'
}
}

请参阅:对象字面量增强

计算属性名称

{3}
1
2
3
4
5
let event = 'click'
let handlers = {
[`on${event}`]: true
}
// 同: handlers = { 'onclick': true }

请参阅:对象字面量增强

提取值

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

Modules 模块

Imports 导入

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

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

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

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

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

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

Exports 导出

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

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

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

1
2
3
4
const firstName = 'Michael';
const lastName = 'Jackson';
const year = 1958;
export { firstName, lastName, year };

1
export * from "lib/math";

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

as 关键字重命名

{2,8,12-14}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
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 // 导出重命名
};

动态加载模块

1
2
3
4
5
6
7
8
9
button.addEventListener('click', event => {
import('./dialogBox.js')
.then(dialogBox => {
dialogBox.open();
})
.catch(error => {
/* Error handling */
})
});

ES2020提案 引入 import() 函数

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

1
2
3
4
5
6
7
8
9
const main = document.querySelector('main')

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

import.meta

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

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

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

导入断言(Import Assertions)

静态导入

1
2
import json from "./package.json" assert {type: "json"}
// 导入 json 文件中的所有对象

动态导入

1
2
const json = 
await import("./package.json", { assert: { type: "json" } })

Generators

Generator 函数

1
2
3
4
function* idMaker () {
let id = 0
while (true) { yield id++ }
}

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

情况很复杂。
请参阅:Generators

For..of + 迭代器(iterator)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
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 接口的关系

1
2
3
4
5
6
7
8
var gen = {};
gen[Symbol.iterator] = function* () {
yield 1;
yield 2;
yield 3;
};

[...gen] // => [1, 2, 3]

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

Symbol.iterator 属性

1
2
3
4
function* gen() { /* some code */ }
var g = gen();

g[Symbol.iterator]() === g // true

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

另见


评论
avatar
竹山一叶
技术分享 个人心得
Follow Me
公告
欢迎光临小站,这里是我日常工作和学习中收集和整理的总结,希望能对你有所帮助:)

本站的内容经过个人加工总结而来,也参考了网友们分享的资料,如有侵权,请第一时间联系我,我将及时进行修改或删除😊
目录
  1. 1. 常用
    1. 1.1. 块范围
      1. 1.1.1. Let
      2. 1.1.2. Const
    2. 1.2. 反引号字符串
      1. 1.2.1. 插值
      2. 1.2.2. 多行字符串
    3. 1.3. 二进制和八进制文字
    4. 1.4. 指数运算符
    5. 1.5. 新方法
      1. 1.5.1. 新的字符串方法
      2. 1.5.2. 新的数字方法
      3. 1.5.3. 新的 Math 方法
      4. 1.5.4. 新的 Array 方法
    6. 1.6.
      1. 1.6.1. 构造函数
      2. 1.6.2. 方法
      3. 1.6.3. 调用超类方法
      4. 1.6.4. 静态方法
    7. 1.7. 私有类
      1. 1.7.1. 静态私有类
  2. 2. Promises
    1. 2.1. 做出承诺
    2. 2.2. 使用 Promises
    3. 2.3. 在 finally 中使用 Promise
    4. 2.4. Promise 函数
    5. 2.5. Async-await
  3. 3. 解构 Destructuring
    1. 3.1. 解构赋值
      1. 3.1.1. Arrays
      2. 3.1.2. Objects
    2. 3.2. 默认值
    3. 3.3. 函数参数
    4. 3.4. 默认值
    5. 3.5. 重新分配键
    6. 3.6. 循环
    7. 3.7. 对象解构
  4. 4. 扩展运算符 Spread
    1. 4.1. 对象扩展
      1. 4.1.1. 与对象扩展
      2. 4.1.2. 没有对象扩展
    2. 4.2. 数组扩展
      1. 4.2.1. 具有数组扩展
      2. 4.2.2. 没有数组扩展
  5. 5. 函数 Functions
    1. 5.1. 函数参数
      1. 5.1.1. 默认参数
      2. 5.1.2. Rest 参数
      3. 5.1.3. 扩展
    2. 5.2. 箭头函数
      1. 5.2.1. 箭头函数
      2. 5.2.2. 带参数
      3. 5.2.3. 隐式返回
    3. 5.3. 参数设置默认值
    4. 5.4. 与解构赋值默认值结合使用
    5. 5.5. name 属性
    6. 5.6. length 属性
  6. 6. Objects
    1. 6.1. 速记语法
    2. 6.2. 方法
    3. 6.3. Getters and setters
    4. 6.4. 计算属性名称
    5. 6.5. 提取值
  7. 7. Modules 模块
    1. 7.1. Imports 导入
    2. 7.2. Exports 导出
    3. 7.3. as 关键字重命名
    4. 7.4. 动态加载模块
    5. 7.5. import() 允许模块路径动态生成
    6. 7.6. import.meta
    7. 7.7. 导入断言(Import Assertions)
      1. 7.7.1. 静态导入
      2. 7.7.2. 动态导入
  8. 8. Generators
    1. 8.1. Generator 函数
    2. 8.2. For..of + 迭代器(iterator)
    3. 8.3. 与 Iterator 接口的关系
    4. 8.4. Symbol.iterator 属性
  9. 9. 另见
最新文章
网站资讯
文章数目 :
437
已运行时间 :
本站总字数 :
431.6k
本站访客数 :
本站总访问量 :
最后更新时间 :
文章归档文章分类文章标签复制本文标题复制本文地址
随便逛逛