美文网首页
ES6新特性

ES6新特性

作者: 小蜜蜂_1d30 | 来源:发表于2022-04-25 22:45 被阅读0次

1.模板字符串

var name = "小名";
var age= 20;
var message = `你好,${name},我今年${age}了`;
alert(message);

2.Map 和Set
Map是一组键值对的结构,具有极快的查找速度
举个例子,假设要根据同学的名字查找对应的成绩,如果用Array实现,需要两个Array:

var names=['Michael','Bob','Tracy'];
var scores = [95,75,85];

给定一个名字,要查找对应的成绩,就先要在names中找到对应的位置,再从scores取出对应的成绩,Array越长,耗时越长。

如果用Map实现,只需要一个"名字-成绩"的对照表,直接根据名字查找成绩,无论这个表有多大,查找速度都不会变慢。用JavaScript写一个Map如下:

var m = new Map(['Michael',95],['Bob',75],['Tracy',85]);
m.get('Michael');//95

初始化Map需要一个二维数组,或者直接初始化一个空Map。Map具有以下方法

var m = new Map();
m.set('Ada',90);
m.set('Bob',78);
m.has('Ada');//true
m.get('Ada');//90
m.delete('Ada');//删除key'Ada'
m.get('Ada');//undefined

由于一个key只能对应一个value,所以,多次对一个key放入value,后面得值会把前面的冲掉

var m = new Map();
m.set('Ada',67);
m.set('Ada',78);
m.get('Ada');//78

Set
set和Map类似,也是一组key的集合,但不储存value。由于key不能重复,所以在set中,没有重复的key。要创建一个set,需要提供一个Array作为输入,或者直接创建一个空Set:

var s1 = new Set();
var s2 = new Set([1,2,'3']);

重复元素在Set中自动会被过滤:

var s = new Set([1,2,3,3,'3']);
s;//Set{1,2,3,'3'}

通过add(key)方法可以添加元素到set中,可以重复添加,但不会有效果:

s.add(4);
s;//Set{1,2,3,4};
s.add(4);
s;//Set{1,2,3,4}

通过delete(key)方法可以删除元素:

var s = new Set([1,2,3]);
s;//Set{1,2,3}
s.delete(3);
s;//Set{1,2}

3.ES6标准引入了新的iterable类型,Array,Map,Set都属于iterable类型
具有iterable类型的集合可以通过新的for...of循环来遍历。

相关文章

网友评论

      本文标题:ES6新特性

      本文链接:https://www.haomeiwen.com/subject/pxiiertx.html