ECMAScript6之Set结构和Map结构
set数据结构
ES6提供了一个新的数据结构,Set,Set和Array数组相似,但是Set里没有重复的数据,可以说是一个值的集合。
同时,Set数据结构有以下属性和方法:
- size:返回成员总数
- add(value):添加某个值
- delete(value):删除某个值
- has(value):返回一个布尔值,表示Set中是否有该成员
- clear():清除所有成员
- entries():返回一个键值对的遍历器
- keys():返回键名的遍历器
- values():返回键值的遍历器
- forEach():遍历每一个成员
var s = new Set();
s.add(1).add(2).add(2);//这里添加了两次2
alert(s.length); //2
s.has(1); //true
s.has(2); //true
s.has(3); //false
s.delete(2);
s.has(2); //false
WeakSet
WeakSet和Set有很多一样的地方,存的也是不同的值,但是他的成员必须是对象类型的值。
let ws = new WeakSet([{"car":"van"}])
console.log(ws)
同样,WeakSet数据结构也提供了add() delete() has()方法,作用域Set一样,但是要注意的是,WeakSet结构不能便利,所以没有keys() entries() values() forEach()方法
Map
Map对象类似于Object对象,但是键的范围不再限制于字符串,甚至对象也可当做键
var map = new Map();
var map2 = new Map([
["car","van"]
])
var o = {"car":"tractor"};
map.set(o,"content")
console.log(map.get(o))
console.log(map2.get("car"))
我们可以发现,在Map的构造函数中传入参数时,参数是一个二维数组,数组的每一个元素是一个键值对的数组,即car是键,van是键值,也可以使用set方法增加一个键值对,第一个参数是键名,第二个参数是键值。除了set方法,Map结构还有其他的方法
- size:返回成员总数
- set(key, value):设置一个键值对
- get(key):读取一个键值
- has(key):返回一个布尔值,表示某个键是否在结构中
- delete(key):删除某个键
- clear():清除所有成员
- entries():返回实例的键值对遍历器
- keys():返回实例所有键名的遍历器
- values():返回实例所有键值的遍历器
- forEach():遍历每一个键值对
WeakMap数据类型
WeakMap与Map相似,但是WeakMap结构的键名只支持引用类型的数据,像数组、对象、函数
其基本用法与Map相似,只是键名的类型有所限制,而且不支持遍历,也不支持clear()方法
WeakMap和WeakSet结构一样,其键名中的引用类型都是弱引用,随时会被垃圾回收机制回收,如果被回收,其实例中的键值对也会随着消失。
ECMAScript6之Set结构和Map结构的更多相关文章
- js-ES6学习笔记-Set结构和Map结构
http://www.cnblogs.com/lonhon/ 1.ES6 提供了新的数据结构 Set.它类似于数组,但是成员的值都是唯一的,没有重复的值. Set 本身是一个构造函数,用来生成 Set ...
- ES6 Set结构和Map结构(上)
Set ES6提供了新的数据结构--Set,它类似于数组,但是成员的值都是唯一的,没有重复的值. Set本身也是一个构造函数,用来生成Set数据结构 var s = new Set(); [2,3,5 ...
- ES6笔记(6)-- Set、Map结构和Iterator迭代器
系列文章 -- ES6笔记系列 搞ES6的人也是够无聊,把JS弄得越来越像Java.C++,连Iterator迭代器.Set集合.Map结构都出来了,不知道说什么好... 一.简单使用 1. iter ...
- Java开发知识之Java中的Map结构
Java开发知识之Java中的Map结构 一丶Map接口 Map没有实现Collection接口,提供的是Key 到Value的映射. Map中.不能包含相同的Key,每个Key只能映射一个Value ...
- hive笔记:复杂数据类型-map结构
map 结构 1. 语法:map(k1,v1,k2,v2,…) 操作类型:map ,map类型的数据可以通过'列名['key']的方式访问 案例: select deductions['Feder ...
- ES6学习:Map结构的目的和基本用法
Map结构的目的和基本用法 JavaScript的对象(Object)本质上是键值对的集合(Hash结构),但是只能用字符串作为键.这给它的使用带来了很大的限制. 1 2 3 4 5 6 7 8 ...
- [Go语言]从Docker源码学习Go——if语句和map结构
if语句 继续看docker.go文件的main函数 if reexec.Init() { return } go语言的if不需要像其它语言那样必须加括号,而且,可以在判断以前,增加赋值语句 语法 I ...
- seam remote 返回的map结构
map结构的数据,js接收到的结构是elements下面的一个 [ {key:***,value:***}, {key:***,value:***} ] 这样子的集合,需要经过下面代码的转换才能重新变 ...
- set和map结构,class类
1.set数据结构和map数据结构: (1)set: 数据结构set(集合,无序且值不能重复的数据集合,特点是key值和value值相同,没有重复的value //1 创建set ,,]) conso ...
随机推荐
- centos 4.4配置使用 and Nutch搜索引擎(第1期)_ Nutch简介及安装
centos 4.4配置使用 1.Nutch简介 Nutch是一个由Java实现的,开放源代码(open-source)的web搜索引擎.主要用于收集网页数据,然后对其进行分析,建立索引,以提供相应的 ...
- AutoPostBack通过现象看本质
在做人事档案管理系统时遇到一个功能需要实现前台数据(实时)与后台进行交互,解决这个问题首先想到的是应用控件的AutoPostBack属性.本以为这个问题就这样解决了(不用javascript.jque ...
- Step one : 熟悉Unix/Linux Shell 常见命令行 (四)
4.了解/etc目录下的各种配置文章,学会查看/var/log下的系统日志,以及/proc下的系统运行信息 了解/etc目录下的各种配置文章 /etc/hosts 主机配置文件 /etc/netwo ...
- c# in deep 之Lambda表达式于LINQ表达式结合后令人惊叹的简洁(2)
当Lambda表达式和LINQ一起使用时,我们会发现原本冗长的代码会变得如此简单.比如我们要打印0-10之间的奇数,让其从高到低排列并求其平方根,现在只用一行代码即可完成其集合的生成,直接上代码: v ...
- [转]Installing Snow Leopard (Client) on VMware Fusion 6.0.3
Source: http://inficererk.wordpress.com/2014/05/29/installing-snow-leopard-client-on-vmware-fusion-6 ...
- h5 localStorage存储大小(转)
摘要 HTML5 的本地存储 API 中的 localStorage 与 sessionStorage 在使用方法上是相同的,区别在于 sessionStorage 在关闭页面后即被清空,而 loca ...
- C#计算两个文件的相对目录算法
C#计算两个文件的相对目录算法 楼主大菜鸟一只,第一次写技术博客,如果有概念错误或代码不规范的地方,还请各位多多批评指正.话不多说,来看题: 前一阵子开发了一个用户控件,里面调用了很多css,js等资 ...
- 框架的设计之IRepository还是IRepository<T>
[Yom框架]漫谈个人框架的设计之[是IRepository还是IRepository<T>]? 前言 ...
- WCF引用方式
WCF之各种WCF引用方式 写在开头:本文内容来自 WCF全面解析中的一个经典例子,如果你已经看过了,那么可以忽略本文,本文旨在和大家分享不一样的WCF使用方法. 准备工作: 1.创建解决方案WCFS ...
- 免费的Visual Studio的插件
在做了深入(的)研究之后(通过在google网站搜索),,我编译了15个免费Visual Studio 2005插件表..其中一些插件将提高您(的)代码(的)质量,,另外一些能使您编译(的)更快,,但 ...