首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

jsSet基本使用

ECMAScript 6 新增的 Set 是一种新集合类型,为这门语言带来集合数据结构。Set 在很多方面都像是加强的 Map,这是因为它们的大多数 API 和行为都是共有的。 基本API 1....创建Set实例 使用 new 关键字和 Set 构造函数可以创建一个空集合: const s = new Set(); 如果想在创建的同时初始化实例,则可以给 Set 构造函数传入一个可迭代对象,其中需要包含插入到新集合实例中的元素...(Set 可以包含任何 JavaScript 数据类型作为值): const s = new Set(["val1", 1, true, {}, undefined, function fun() {}...Set实例转数组 const s = new Set([1, 2, 3]); Array.from(s); // [1, 2, 3] 3. size属性 size: 获取Set实例的元素个数: const...迭代 keys():返回键名; values(): 返回键值; entries(): 返回键值对; 键名=键值 const s = new Set(); s.add(1).add(2).add(3);

2.6K30

jsset和map的区别_list和set

Set Set 对象允许你存储任何类型的值,无论是原始值或者是对象引用。它类似于数组,但是成员的值都是唯一的,没有重复的值。 Set 本身是一个构造函数,用来生成Set 数据结构。...Set函数可以接受一个数组(或者具有 iterable 接口的其他数据结构)作为参数,用来初始化。 Set中的特殊值: Set 对象存储的值总是唯一的,所以需要判断两个值是否恒等。...{} {} 两个空对象的指针不一样,所以会重复 Set实例对象的属性: size:返回Set实例的成员总数。...const set = new Set(['a', 'b', 'c']) for (let item of set.keys()) { console.log(item) } // a // b /....都能通过迭代器进行for…of遍历; 4.Set的值是唯一的可以做数组去重,Map由于没有格式限制,可以做数据存储 5.map和set都是stl中的关联容器,map以键值对的形式存储,key=value

3.1K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【C++】STL 容器 - set 集合容器 ② ( set 集合容器常用 api 简介 | 使用迭代器进行正向迭代与反向迭代 | 集合容器插入元素 | 插入单个元素 | 插入多个元素 )

    一、set 集合容器遍历 1、使用迭代器进行正向迭代与反向迭代 std::set 集合容器 提供了 begin、end、rbegin 和 rend 这几个成员函数,用于 获取 迭代访问链表中的元素 的...rend(); const_reverse_iterator rend() const; 迭代器的位置如下图所示 : 正向迭代示例 : // 遍历 set 集合容器 , 正向迭代 for (set...= se.end(); it++) { cout << *it << " "; } // 回车换行 cout << endl; 反向迭代示例 : // 遍历 set 集合容器 , 反向迭代...集合容器 , 正向迭代 for (set::iterator it = se.begin(); it !...- insert 函数 调用 set 容器的 insert 函数 , 传入 2 个迭代器对象 , 可以将另外一个容器指定范围的元素插入到 set 集合容器中 , 插入的多个元素会在 set 容器中自动排序

    87210

    JS 中的 (Weak)Set 和 (Weak)Map

    Set 是一个构造函数,它有一个可选的参数一个可迭代对象。如果传递了这个参数它的所有元素将不重复地被添加到新的 Set中。如果不指定此参数或其值为null,则新的Set为空。...(5) [] [] Set(5) {} {} Set(5) */ [@@iterator]() Set迭代器函数,默认是values函数。...它和 JS 对象不同,JS 对象只能用字符串和Symbol作为键,而Map可以使用任何值。 除了键类型上的不同,它和Object还有以下不同: Map中的键值是有序的,而添加到对象中的键则不是。...Map可直接进行迭代,而 Object 的迭代需要先获取它的键数组,然后再进行迭代。 Object都有自己的原型,原型链上的键名有可能和你自己在对象上的设置的键名产生冲突。...entries() 返回一个新的包含[key, value]对的Iterator对象,返回的迭代器的迭代顺序与Map 对象的插入顺序相同。它就像直接迭代Map对象一样。

    2.1K20

    js数组操作--使用迭代方法替代for循环

    前言 数组的迭代方法,这个想必大家都不陌生了,可能刚入门的人暂时还没接触到这个。但是以后的开发中,肯定会用得上的。...我自身的一个使用经历就是,如果迭代方法用的适当,不但可以减少代码量,也能使代码可读性更强,性能上的优化也是肯定的了。...还有一个就是,我本身在数组的遍历上,基本都是用for循环进行操作,在开始使用了迭代方法之后,我for循环用的很少。如果以后我更加熟练迭代方法的话,for使用会更少,也希望这样能帮助大家学习迭代方法。...后续 今天的分享就到这里了,关于数组的迭代方法的使用技巧,上面说的是冰山一角,更多也是要靠大家自己去挖掘。以后如果又有发现什么好玩的,实用的,也会第一时间分享给大家。

    3.3K41

    Node.js 中的异步迭代

    从 Node.js v10.0.0 开始,异步迭代器就出现中了,最近它们在社区中的吸引力越来越大。在本文中,我们将讨论异步迭代器的作用,还将解决它们可能用于什么目的的问题。...什么是异步迭代器 那么什么是异步迭代器?它们实际上是以前可用的迭代器的异步版本。...我们还获得了 for-await-of 循环,以帮助我们循环异步迭代器。就像 for-of 循环是针对同步迭代器一样。...除了流,当前没有太多支持异步迭代的结构,但是可以将符号手动添加到任何可迭代的结构中,如此处所示。 作为异步迭代器流 异步迭代器在处理流时非常有用。可读流、可写流、双工流和转换流都支持异步迭代器。...原文链接 https://blog.risingstack.com/async-iterators-in-node-js/

    1.7K40

    js入门(ES6)---认识Symbol、Map、 Set

    认识Symbol、Map、 Set、Proxy Symbol 用法 方法 Symbol.for() Symbol.keyFor() 使用场景 Map 用法 添加/删除 迭代 合并Map Set...; Map 保存键值对 二维数组,查找速度快 用法 let myMap = new Map(); value可以为字符串,对象,函数,NAN,整型等(任何值或对象) 添加/删除 添加 myMap.set...(key, value); 删除 myMap.delete(key); 迭代 for of for (var [key, value] of myMap) { xxxxx } 只遍历key for...删除 mySet.delete(2); 删除或者添加可以处理数据 var a = [1, 2, 3]; var data = new Set([...a].filter(x => x%2==0));...后续会推出 每个平台的详细搭建过程 前端:js入门 vue入门 vue开发小程序 等 后端: java入门 springboot入门等 服务器:mysql入门 服务器简单指令 云服务器运行项目

    1.7K30

    ES6笔记(6)-- Set、Map结构和Iterator迭代

    系列文章 -- ES6笔记系列 搞ES6的人也是够无聊,把JS弄得越来越像Java、C++,连Iterator迭代器、Set集合、Map结构都出来了,不知道说什么好......一、简单使用 1. iterator 学过C++的人应该知道这是个迭代器对象,拥有一个指针,指向数据结构中的某个成员 JS中的iterator也有类似的功能,JS内部为一些数据结构实现了iterator...迭代器的接口,让我们可以方便的使用 var [a, b, ...c] = [1, 2, 3, 4]; c // [3, 4] 如上,解构赋值以及扩展运算符的便利,多亏了内部实现的默认iterator迭代器接口...可见结果输出是一个对象,该对象拥有done这个迭代器是否遍历完成的状态,以及当前指向项的值 看到这里,结合上述两个例子,应该知道可以通过Symbol.iterator与generator的结合,创建出一个...iterator迭代器,比如: var obj = {}; obj[Symbol.iterator] = function* () { yield 1; yield 2; yield 3;

    1.4K10

    【C++】STL 容器 - set 集合容器 ③ ( set 集合容器常用 api 简介 | 删除元素 | 删除指定值的元素 | 删除指定迭代器位置元素 | 删除指定迭代器范围元素 )

    文章目录 一、删除元素 1、删除指定值的元素 - erase 函数 2、删除指定迭代器位置的元素 - erase 函数 3、删除指定迭代器范围的元素 - erase 函数 4、删除集合中的所有元素 -...- erase 函数 set#erase 函数 还可以传入一个 指向指定元素位置的 迭代器 对象 , 作为参数 , 删除该迭代器指向的元素 ; 函数原型如下 : iterator erase (iterator...position); 参数解析 : position 参数是一个指向要删除元素的迭代器 ; 返回值解析 : 该函数的返回值是一个迭代器 , 指向被删除元素之后的下一个元素 ; 使用示例 : 在下面的示例中...- erase 函数 调用 set#erase 函数 , 可以传入两个迭代器参数 , 这两个迭代器划定了本集合容器的一个范围 , 执行该函数可删除该范围的所有元素 ; 函数原型如下 : iterator...erase (iterator first, iterator last); 参数解析 : first 和 last 是要删除元素范围的迭代器 ; 返回值解析 : 返回值是一个迭代器 , 指向被删除范围之后的下一个元素

    67310

    JS】230-迭代器与 for of的使用和原理

    ,比如有的时候我们仅需要数组中的值,但有的时候不仅需要使用值还需要使用索引,ES6 为数组、Map、Set 集合内建了以下三种迭代器: entries() 返回一个遍历器对象,用来遍历[键名, 键值]组成的数组...类型的 keys() 和 values() 返回的是相同的迭代器,这也意味着在 Set 这种数据结构中键名与键值相同。...数组和 Set 集合的默认迭代器是 values() 方法,Map 集合的默认迭代器是 entries() 方法。...这也就是为什么直接 for of 遍历 Set 和 Map 数据结构,会有不同的数据结构返回: const values = new Set([1, 2, 3]); for (let value of...,如果没有正常的迭代完成,并且迭代器有 return 方法时,就会执行该方法。

    89641
    领券