注册会员
×

已有账号? 请点击

使用其他方式登录

ES6Map与Set用法

发布2023-06-11 浏览525次

详情内容

这是一个

本文主要介绍了 Set 以及 Map 数据结构,对他们实例方法、遍历、以及类型转换进行了详细的讲解。

什么是Set和Map

Set 是不包含重复值的列表。你一般不会像对待数组那样来访问 Set 中的某个项;相反更常见的是,只在 Set 中检查某个值是否存在。

Map 则是键与相对应的值的集合。因此,Map中的每个项都存储了两块数据,通过指定所需读取的键即可检索对应的值。 Map 常被用作缓存,存储数据以便此后快速检索。

一、Set 数据结构

ES6 提供了新的数据结构 Set。它类似于数组,但是成员的值都是唯一的,没有重复的值。Set 本身是一个构造函数,用来生成 Set 数据结构。Set 数据结构我们一般运用在电商网站的搜索历史关键字的存储。

Set 本身是一个构造函数,用来生成 Set 数据结构。

const s = new Set();


Set 函数可以接受一个数组作为参数,用来初始化。

const set = new Set([1, 2, 3, 4, 4]); // {1, 2, 3, 4}


通过示例可以看出,成员的值都是唯一的,没有重复的值。
请添加图片描述

二、实例方法

  • add(value):添加某个值,返回 Set 结构本身。

  • delete(value):删除某个值,返回一个布尔值,表示删除是否成功。

  • has(value):返回一个布尔值,表示该值是否为 Set 的成员。

  • clear():清除所有成员,没有返回值。

const s = new Set();s.add(1).add(2).add(3); // 向 set 结构中添加值s.delete(2); // 删除 set 结构中的 2 值,返回一个布尔值,表示删除是否成功。s.has(1); // 表示 set 结构中是否有 1 这个值 返回布尔值,表示该值是否为 Set 的成员。s.clear(); // 清除 set 结构中的所有值// 注意:删除的是元素的值,不是代表的索引。


示例代码:

新建 index.html 文件,代码如下:

<!DOCTYPE html><html>
  <head></head>
  <body><script>  var s1 = new Set();  // 向 set 结构中添加值,使用 add 方法  s1.add(1).add(2).add("a");  document.write("s1 添加值之后的数据个数为:" + s1.size + "<br>");  // 从 set 结构中删除值 用到的方法是 delete  // 查看是否删除成功,返回一个布尔值  const r1 = s1.delete("a");  document.write("s1 删除值之后的数据个数为:" + s1.size + "<br>");  document.write("s1 是否成功删除这个值:" + r1 + "<br>");  // 判断某一个值是否是 Set 数据结构中的成员,使用 has ,返回值是一个布尔值  const r2 = s1.has("a");  // 由于前面已经将 a 值删除,所以这里返回的是 false  document.write("s1 数据中是否有这个值:" + r2 + "<br>");  const r3 = s1.has(1);  // set 结构中有 1 这个值,所以这里返回的是 true  document.write("s1 数据中是否有这个值:" + r3 + "<br>");  // 清空 set 数据结构中的值,使用 clear,清空成功数据个位为 0  s1.clear();  document.write("s1 清空值后的数据个数为:" + s1.size);</script>
  </body></html>


显示效果:
请添加图片描述

三、遍历

Set 结构的实例与数组一样,也拥有 forEach 方法,用于对每个成员执行某种操作,没有返回值。

s.forEach((value) => console.log(value));


示例代码:

新建 test.js 文件,代码如下:

// 遍历 set 数据结构,从中取值const s1 = new Set(["a", "b", "c", "A", "B"]);s1.forEach((value) => {
  console.log(value);});


显示效果:
请添加图片描述

四、类型转换

Array

// Array 转 Setvar mySet = new Set(["value1", "value2", "value3"]);// 用...操作符,将 Set 转 Arrayvar myArray = [...mySet];


在终端使用 node 命令运行:
请添加图片描述

String

// String 转 Setvar mySet = new Set('hello');// Set(4) {"h", "e", "l", "o"}copy
Set 中 toString 方法是不能将 Set 转换成 String。


在终端使用 node 命令运行:
请添加图片描述

五、Set 对象作用

数组去重

var mySet = new Set([1, 2, 3, 4, 4]);[...mySet];// [1, 2, 3, 4]


在终端使用 node 命令运行:
请添加图片描述
并集

var a = new Set([1, 2, 3]);var b = new Set([4, 3, 2]);var union = new Set([...a, ...b]);// {1, 2, 3, 4}


在终端使用 node 命令运行:
请添加图片描述

交集

var a = new Set([1, 2, 3]);var b = new Set([4, 3, 2]);var intersect = new Set([...a].filter(x => b.has(x)));// {2, 3}


在终端使用 node 命令运行:
请添加图片描述
差集

var a = new Set([1, 2, 3]);var b = new Set([4, 3, 2]);var difference = new Set([...a].filter(x => !b.has(x)));// {1}


在终端使用 node 命令运行:
请添加图片描述

六、Map

Map 对象保存键值对,任何值(对象或者原始值) 都可以作为一个键或一个值。它类似于对象,也是键值对的集合,但是“键”的范围不限于字符串,各种类型的值(包括对象)都可以当作键。也就是说,Object 结构提供了“字符串 — 值”的对应,Map 结构提供了“值 — 值”的对应,是一种更完善的 Hash 结构实现。如果你需要“键值对”的数据结构,Map 比 Object 更合适。

var m = new Map();var o = { p: "Hello World" };m.set(o, "content");m.get(o); // "content"m.has(o); // truem.delete(o); // truem.has(o); // false


上面代码使用 set 方法,将对象 o 当作 m 的一个键,然后又使用 get 方法读取这个键,接着使用 delete 方法删除了这个键。在终端使用 node 命令运行:
请添加图片描述

七、实例的属性和操作方法

Map 结构的实例有以下属性和操作方法。

size 属性

size 属性返回 Map 结构的成员总数。

let map = new Map();map.set("foo", true);map.set("bar", false);map.size; // 2


新建 test1.js 文件,示例代码如下:

let map = new Map();map.set("foo", true);map.set("bar", false);console.log(map.size);


效果如下:
请添加图片描述
set(key, value)

set 方法设置 key 所对应的键值,然后返回整个 Map 结构。如果 key 已经有值,则键值会被更新,否则就新生成该键。

var m = new Map();m.set("edition", 6); // 键是字符串m.set(262, "standard"); // 键是数值m.set(undefined, "nah"); // 键是 undefined


在终端使用 node 命令运行:
请添加图片描述
get(key)

get 方法读取 key 对应的键值,如果找不到 key,返回 undefined。

var m = new Map();var hello = function () {
  console.log("hello");};m.set(hello, "Hello ES6!"); // 键是函数m.get(hello); // Hello ES6!


在终端使用 node 命令运行:
请添加图片描述
has(key)

has 方法返回一个布尔值,表示某个键是否在 Map 数据结构中。

var m = new Map();m.set("edition", 6);m.set(262, "standard");m.set(undefined, "nah");m.has("edition"); // truem.has("years"); // falsem.has(262); // truem.has(undefined); // true


在终端使用 node 命令运行:
请添加图片描述
delete(key)

delete 方法删除某个键,返回 true。如果删除失败,返回 false。

var m = new Map();m.set(undefined, "nah");m.has(undefined); // truem.delete(undefined);m.has(undefined); // false


在终端使用 node 命令运行:
请添加图片描述
clear()

clear 方法清除所有成员,没有返回值。

let map = new Map();map.set("foo", true);map.set("bar", false);map.size; // 2map.clear();map.size; // 0


在终端使用 node 命令运行:
请添加图片描述

八、Map 的迭代

对 Map 进行遍历,以下两个最高级。

for…of

遍历所有键值对:

var myMap = new Map();myMap.set(0, "zero");myMap.set(1, "one");// 将会显示两个 log。 一个是 "0 = zero" 另一个是 "1 = one"// 方法一for (var [key, value] of myMap) {
  console.log(key + " = " + value);}// 方法二for (var [key, value] of myMap.entries()) {
  console.log(key + " = " + value);}


  • 这个 entries 方法返回一个新的 Iterator 对象,它按插入顺序包含了 Map 对象中每个元素的 [key, value] 数组。

在终端使用 node 命令运行:
请添加图片描述
遍历所有键:

新建 test2.js 文件,代码如下:

var myMap = new Map();myMap.set(0, "zero");myMap.set(1, "one");// 将会显示两个 log。 一个是 "0" 另一个是 "1"for (var key of myMap.keys()) {
  console.log(key);}


  • 这个 keys 方法返回一个新的 Iterator 对象, 它按插入顺序包含了 Map 对象中每个元素的键。

在终端使用 node 命令运行:
请添加图片描述
遍历所有值:

新建 test3.js 文件,代码如下:

var myMap = new Map();myMap.set(0, "zero");myMap.set(1, "one");// 将会显示两个 log。 一个是 "zero" 另一个是 "one"for (var value of myMap.values()) {
  console.log(value);}


  • 这个 values 方法返回一个新的 Iterator 对象,它按插入顺序包含了 Map 对象中每个元素的值。

在终端使用 node 命令运行:
请添加图片描述
forEach()

新建 test4.js 文件,代码如下:

var myMap = new Map();myMap.set(0, "zero");myMap.set(1, "one");// 将会显示两个 logs。 一个是 "0 = zero" 另一个是 "1 = one"myMap.forEach(function (value, key) {
  console.log(key + " = " + value);}, myMap);


在终端使用 node 命令运行:
请添加图片描述

九、Map 对象的操作

Map 转为数组

前面已经提过,Map 转为数组最方便的方法,就是使用扩展运算符(…)。

let myMap = new Map().set(true, 7).set({ foo: 3 }, ["abc"]);[...myMap];// [ [ true, 7 ], [ { foo: 3 }, [ 'abc' ] ] ]


在终端使用 node 命令运行:
请添加图片描述
数组转为 Map

将数组转入 Map 构造函数,就可以转为 Map。

new Map([
  [true, 7],
  [{ foo: 3 }, ["abc"]],]);// Map {true => 7, Object {foo: 3} => ['abc']}


在终端使用 node 命令运行:
请添加图片描述
Map 转为对象

如果所有 Map 的键都是字符串,它可以转为对象。

function strMapToObj(strMap) {
  let obj = Object.create(null);
  for (let [k, v] of strMap) {obj[k] = v;
  }
  return obj;}let myMap = new Map().set("yes", true).set("no", false);strMapToObj(myMap);// { yes: true, no: false }


在终端使用 node 命令运行:
请添加图片描述
对象转为 Map

function objToStrMap(obj) {
  let strMap = new Map();
  for (let k of Object.keys(obj)) {strMap.set(k, obj[k]);
  }
  return strMap;}objToStrMap({ yes: true, no: false });// [ [ 'yes', true ], [ 'no', false ] ]


在终端使用 node 命令运行:
请添加图片描述

总结

本文主要讲解了 Set 以及 Map 数据结构,对他们实例方法、遍历、以及类型转换等知识点。

,可点击上面演示按钮看HTML页面效果,有需要可直接下载或开通SVIP终生会员全站免费下载。
点击QQ咨询
开通会员
返回顶部
×
  • 微信支付
  • 支付宝付款
微信扫码支付
微信扫码支付
请使用微信描二维码支付
×

提示信息

×

选择支付方式

  • 微信支付
  • 支付宝付款
确定支付下载