ES8新特性整理

前言

ES8 或者说是 ES2017 已经在今年6月底的时候被 TC39 正式发布。似乎我们在最近的一年里就已经谈论了很多有关 ECMA 的事情。现在的 ES 标准每年发布一次。我们都知道 ES6 是在2015年发布的,ES7 是在2016年发布的,但是估计会有很少数人知道 ES5 是在何时发布的。答案是2009年,是在 JavaScript 逐渐变的流行之前发布的。

字符串填充

在 String 对象中,ES8 增加了两个新的函数: padStart 和 padEnd 。正如其名,这俩函数的作用就是在字符串的头部和尾部增加新的字符串,并且返回一个具有指定长度的新的字符串。

语法:

1
2
3
str.padStart(targetLength [, padString])

str.padEnd(targetLength [, padString])

这俩函数的第一个参数(必输)是 targetLength ,这个参数指的是设定这俩函数最后返回的字符串的长度。第二个参数 padString 是可选参数,代表你想要填充的内容,默认值是空格。

示例:

1
2
3
4
5
6
7
8
9
10
11
'es8'.padStart(2);          // 'es8'
'es8'.padStart(5); // ' es8'
'es8'.padStart(6, 'woof'); // 'wooes8'
'es8'.padStart(14, 'wow'); // 'wowwowwowwoes8'
'es8'.padStart(7, '0'); // '0000es8'

'es8'.padEnd(2); // 'es8'
'es8'.padEnd(5); // 'es8 '
'es8'.padEnd(6, 'woof'); // 'es8woo'
'es8'.padEnd(14, 'wow'); // 'es8wowwowwowwo'
'es8'.padEnd(7, '6'); // 'es86666'

浏览器支持情况:

Chrome Firefox Edge IE Opera Safari
57 48 15 15 44 10

values和entries函数

在 Object 中,ES8 也新增了两个新的函数,分别是 Object.values 函数和 Object.entries 函数。Object.values 函数将会返回一个数组,该数组的内容是函数参数(一个对象)可遍历属性的属性值。数组中得到的属性值的顺序与你在对参数对象使用 for in 语句时获取到的属性值的顺序一致。

Object.values

语法:

1
Object.values(obj)

参数 obj 就是源对象,它可以是一个对象或者一个数组(因为数组可以看作是数组下标为 key ,数组元素为 value 的特殊对象)。

示例:

1
2
3
4
5
6
7
8
9
10
11
const obj = { x: 'xxx', y: 1 };
Object.values(obj); // ['xxx', 1]

const obj = ['e', 's', '8']; // same as { 0: 'e', 1: 's', 2: '8' };
Object.values(obj); // ['e', 's', '8']

// when we use numeric keys, the values returned in a numerical
// order according to the keys
const obj = { 10: 'xxx', 1: 'yyy', 3: 'zzz' };
Object.values(obj); // ['yyy', 'zzz', 'xxx']
Object.values('es8'); // ['e', 's', '8']

浏览器支持情况:

Chrome Firefox Edge IE Opera Safari
54 47 (yes) No support No support No support

Object.entries

Object.entries 函数与 Object.values 函数类似,也是返回一个数组,只不过这个数组是一个以源对象(参数)的可枚举属性的键值对为数组 [key, value] 的 n 行 2 列的数组。它的返回顺序与 Object.values 函数类似。

语法:

1
Object.entries(obj)

示例:

1
2
3
4
5
6
7
8
9
const obj = { x: 'xxx', y: 1 };
Object.entries(obj); // [['x', 'xxx'], ['y', 1]]

const obj = ['e', 's', '8'];
Object.entries(obj); // [['0', 'e'], ['1', 's'], ['2', '8']]

const obj = { 10: 'xxx', 1: 'yyy', 3: 'zzz' };
Object.entries(obj); // [['1', 'yyy'], ['3', 'zzz'], ['10': 'xxx']]
Object.entries('es8'); // [['0', 'e'], ['1', 's'], ['2', '8']]

浏览器支持情况:

Chrome Firefox Edge IE Opera Safari
54 47 (yes) No support No support 10.1

getOwnPropertyDescriptors函数

Object 中还有一个新成员,那就是 Object.getOwnPropertyDescriptors 函数。该函数返回指定对象(参数)的所有自身属性描述符。所谓自身属性描述符就是在对象自身内定义,不是通过原型链继承来的属性。

语法:

1
Object.getOwnPropertyDescriptors(obj)

obj 参数即为源对象,该函数返回的每个描述符对象可能会有的 key 值分别是:configurable、enumerable、writable、get、set和value。

示例:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
const obj = { 
get es7() { return 777; },
get es8() { return 888; }
};
Object.getOwnPropertyDescriptor(obj);
// {
// es7: {
// configurable: true,
// enumerable: true,
// get: function es7(){}, //the getter function
// set: undefined
// },
// es8: {
// configurable: true,
// enumerable: true,
// get: function es8(){}, //the getter function
// set: undefined
// }
// }

浏览器支持情况:

Chrome Firefox Edge IE Opera Safari
54 50 (yes) ? 41 10

结尾逗号

此处结尾逗号指的是在函数参数列表中最后一个参数之后的逗号以及函数调用时最后一个参数之后的逗号。ES8 允许在函数定义或者函数调用时,最后一个参数之后存在一个结尾逗号而不报 SyntaxError 的错误。

示例:

1
2
3
4
5
6
7
//函数声明时
function es8(var1, var2, var3,) {
// ...
}

//函数调用时
es8(10, 20, 30,);

ES8的这项新特性受启发于对象或者数组中最后一项内容之后的逗号,如 [10, 20, 30,] 和 { x: 1, }

异步函数

由 async 关键字定义的函数声明定义了一个可以异步执行的函数,它返回一个 AsyncFunction 类型的对象。异步函数的内在运行机制和 Generator 函数非常类似,但是不能转化为 Generator 函数。

ps: 不理解 Generator 函数的读者可以参考阮一峰大师的ES6入门中关于Generator函数的讲解

示例:

1
2
3
4
5
6
7
8
9
10
11
12
function fetchTextByPromise() {
return new Promise(resolve => {
setTimeout(() => {
resolve("es8");
}, 2000);
});
}
async function sayHello() {
const externalFetchedText = await fetchTextByPromise();
console.log(`Hello, ${externalFetchedText}`); // Hello, es8
}
sayHello();

上述代码中, sayHello 函数的调用将会导致在2秒之后打印 Hello, es8 。继续来看一段代码:

1
2
3
console.log(1);
sayHello();
console.log(2);

输出将会变成:

1
2
3
1 // immediately
2 // immediately
Hello, es8 // after 2 seconds

之所以会打印上述内容,那是因为异步函数不会阻塞程序的继续执行。

浏览器支持情况:

Chrome Firefox Edge IE Opera Safari
55 52 (yes) ? 42 10.1

共享内存与原子操作

当内存被共享时,多个线程可以并发读、写内存中相同的数据。原子操作可以确保那些被读、写的值都是可预期的,即新的事务是在旧的事务结束之后启动的,旧的事务在结束之前并不会被中断。这部分主要介绍了 ES8 中新的构造函数 SharedArrayBuffer 以及拥有许多静态方法的命名空间对象 Atomic 。

Atomic 对象类似于 Math 对象,拥有许多静态方法,所以我们不能把它当做构造函数。 Atomic 对象有如下常用的静态方法:

  • add /sub - 为某个指定的value值在某个特定的位置增加或者减去某个值
  • and / or /xor - 进行位操作
  • load - 获取特定位置的值

浏览器支持情况:

Chrome Firefox Edge IE Opera Safari
No support 55 No support No support No support No support

取消模版字符串限制( ES9 )

使用 ES6 中规定的模版字符串,我们可以做如下事情:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
const esth = 8;
helper`ES ${esth} is `;
function helper(strs, ...keys) {
const str1 = strs[0]; // ES
const str2 = strs[1]; // is
let additionalPart = '';
if (keys[0] == 8) { // 8
additionalPart = 'awesome';
}
else {
additionalPart = 'good';
}

return `${str1} ${keys[0]} ${str2} ${additionalPart}.`;
}

上述代码的返回值将会是 ES 8 is awesome 。如果 esth 是 7 的话,那么返回值将会是 ES 7 is good 。这样做完全没有问题,很酷!但是我们在使用模版字符串的时候,有一个限制,那就是不能使用类似于 \u 或者 \x 的子字符串, ES9 正在处理这个问题。详情请查阅MDN或者TC39文档。

浏览器支持情况:

Chrome Firefox Edge IE Opera Safari
No support 53 No support No support No support No support

转自:Github-ES8 新特性一览

×

纯属好玩

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

文章目录
  1. 1. 前言
    1. 1.1. 字符串填充
    2. 1.2. values和entries函数
      1. 1.2.1. Object.values
      2. 1.2.2. Object.entries
    3. 1.3. getOwnPropertyDescriptors函数
    4. 1.4. 结尾逗号
    5. 1.5. 异步函数
    6. 1.6. 共享内存与原子操作
    7. 1.7. 取消模版字符串限制( ES9 )
,