JavaScript --Map和Set, Iterable
来源:互联网 发布:广东软件行业协会 招聘 编辑:程序博客网 时间:2024/05/18 14:22
Map
Map是一组键值对的结构,具有极快的查找速度。比如,要根据同学的名字查找对应的成绩,我们用Map实现,只需要一个“名字“ - ”成绩“的对照表,直接根据名字查找成绩,无论这个表多大,查找速度都不会变慢。用JavaScript写一个Map:
var m = new Map([['Michael', 95], ['Bob', 75], ['Tracy', 85]]);m.get('Michael');
从而直接得到Michael的成绩95了,初始化Map需要一个二维数组,或者直接初始化一个空Map,Map具有以下的方法:
var m = new Map(); //空Mapm.set('Adam', 67);//添加新的key-valuem.set('Bob', 59);m.has('Adam');//是否存在key 'Adam': truem.get('Adam');67m.delete('Adam');//删除key 'Adam'm.get('Adam');
Set
Set和Map类似,也是一组key的集合,但不存储value。由于key不能重复,所以在Set中,没有重复的key。要创建一个Set,需要提供一个Array作为输入,或者直接创建一个空的Set:
var s1 = new Set();// 空Setvar s2 = new Set([1, 2, 3]); // 含1, 2, 3var s = new Set([1, 2, 3, 3, '3']);s;// Set {1, 2, 3, '3'}
1. add(key)方法可以添加元素到Set中,可以重复添加,但不会有效果。
>>> s.add(4)>>> s{1, 2, 3, 4}>>> s.add(4)>>> s{1, 2, 3, 4}
var s = new Set([1, 2, 3]);s; // Set {1, 2, 3}s.delete(3);s; // Set {1, 2}
Map和Set是ES6标准的新增的数据类型,要确保浏览器支持使用。
Iterable
遍历Array可以使用下标循环,遍历Map和Set就无法使用下标。为了统一集合类型,ES6标准引入了新的iterable类型,Array、Map和Set都属于iterable类型。具有iterable类型的集合都可以通过新的for ... of循环来遍历。
for ... of循环是ES6引入的新的语法,例如:
'use strict';var a = [1, 2, 3];for(var x of a) {}
用for ... of 循环遍历集合,用法很简单,例子如下:
var a = ['A', 'B', 'C'];var s = new Set(['A', 'B', 'C']);var m = new Map([1, 'x'], [2, 'y'], [3, 'z']);for(var x of a) {alert(x);}for(var x of s) {alert(x);}for(var x of m) {alert(x[0] + '=' + x[1]);}
for...in 循环遍历的实际是对象的属性名称。一个Array数组实际上也是一个对象,它的每个元素的索引被称为一个属性。例如
var a = ['A', 'B', 'C'];a.name = 'Hello';for(var x in a) {alert(x); // '0', '1', '2', 'name'}
for ... in 循环将把name包含在内,但Array的length属性不包含在内。
for ... of 循环只循环集合本身的元素:
var a = ['A', 'B', 'C'];a.name = 'Hello';for(var x of a) {alert(x);// 'A', 'B', 'C'}
更好的方式是直接是使用iterable内置的forEach方法,它接收一个函数,每次迭代都自动回调该函数。以Array为例:
var a = ['A', 'B', 'C'];a.forEach(function (element, index, array)) {//element: 指向当前元素的值//index: 指向当前索引//array: 指向Array对象本身alert(element);});
Set与Array类似,但Set没有索引
var s = new Set(['A', 'B', 'C']);s.forEach(function (element, sameElement, set) { alert(element);});
Map的回调函数参数依次为value, key, map本身:
var m = new Map([[1, 'x'], [2, 'y'], [3, 'z']]);m.forEach(function (value, key, map) { alert(value);});
当然,由于JavaScript的函数调用不要求参数必须一致,因此可以忽略它们。
var a = ['A', 'B', 'C'];a.forEach(function (element) { alert(element);});
阅读全文
0 0
- JavaScript --Map和Set, Iterable
- javascript(注意点) map 、 set 、iterable
- Javascript Map和Set
- JavaScript---map和set
- JavaScript--Map和Set介绍
- JavaScript之Set 和 Map
- JavaScript学习笔记六:Map和Set
- Map和Set,javascript新的数据类型
- JavaScript之Set和Map数据结构
- JavaScript(三)Map和Set
- javascript ES6 Map 和Set结构总结
- 07-javascript map&set
- Javascript中Map和Set的理解和使用
- JavaScript学习笔记 CH.2 SEC.7 map和set
- javascript学习(五)— Map和Set
- Iterator && Iterable Collection && Map
- Collection、Map、Iterable
- map( f,Iterable)
- 傅里叶变换直观解释
- pwnable.tw之hacknote
- Requests 之Max retries exceeded with url[Errno 10054]错误新解
- SSH连接Ubuntu虚拟机失败
- 使用phantomjs访问网站,高度自定义headers
- JavaScript --Map和Set, Iterable
- 【STL】map要点及使用
- 实验三之顺序队列的实现
- Excel数据导出到txt文档
- SortList
- 实验二 线性表综合实验之《间接寻址》
- c操作符个人简短总结
- 122. Best Time to Buy and Sell Stock II
- noip2006 金明的预算方案