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

javascript之set和weakset的用法

今天我们来介绍一下数据结构Set和weakset set weakset 简单介绍 Set其实类似于数组,但是其中的成员值都是唯一的,没有重复的值。 如何构造一个Set?...Set本身也是一个构造函数,用来生成Set,其参数可以是空,可以是数组,可以是类似数组的对象(比如NodeList) 如果不清楚NodeList可以看这篇文章: (4条消息) javascript 中的..., 12, 16 } WeakSet的使用其实和Set比较类似,他们的区别主要有两个: WeakSet的成员只能是对象,而不是能是别的类型的值 WeakSet的对象都是弱引用,不能遍历 什么叫弱引用呢...,就是如果其他对象都不再引用该对象,那么垃圾回收机制会自动回收该对象所占用的内存,不考虑该对象还存在于 WeakSet 之中。...关于Set的用法可以参考这篇博客: 【javaScript】之Set的用法_qwerty053的博客-CSDN博客

59320

比较JavaScript中的数据结构(数组与对象)

无论动机是什么,如果不知道什么是数组结构及何时使用应用字们,那学数据结构是一项繁琐且无趣的过程 ? 这篇文章讨论了什么时候使用它们。在本文中,我们将学习数组和对象。...数组中的数据以有序的方式进行结构化,即数组中的第一个元素存储在索引0中,第二个元素存储在索引1中,依此类推。 JavaScript为我们提供了一些内置的数据结构,数组就是其中之一 ?...在数组的末尾添加一个元素: JavaScript 中的数组有一个默认属性 length,它表示数组的长度。除了length属性外,JS还提供了 push() 方法。...在数组的开头添加一个元素: 对于此操作,JavaScript提供了一个称为unshift()的默认方法,此方法将元素添加到数组的开头。...对象 像数组一样,对象也是最常用的数据结构之一。 对象是一种哈希表,允许我们存储键值对,而不是像在数组中看到的那样将值存储在编号索引处。

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

    深入理解 ES6 新增的数据结构 Set 与 WeakSet

    一、Set 1、Set 的基本用法 ES6 提供了新的数据结构 Set,它类似于数组,但是其成员的值都是唯一的,没有重复的值 Set 本身是一个构造函数,用来生成 Set 数据结构 var s = new...数据结构 var ws = new WeakSet(); ws // WeakSet {} 作为构造函数,WeakSet 可以接受一个数组或类数组的对象作为参数,该数组的所有成员,都会自动成为 WeakSet...,a 是一个数组,它有两个成员,也都是数组 将 a 作为 WeakSet 构造函数的参数,a 的成员会自动成为 WeakSet 的成员 2、WeakSet 与 Set 的区别 WeakSet 结构与...set 上面代码试图向 WeakSet 添加一个数值和 Symbol 值,结果报错,因为 WeakSet 只能放置对象 ② WeakSet 中的对象都是弱引用 即垃圾回收机制不考虑 WeakSet 对该对象的引用...也就是说,如果其他对象都不再引用该对象,那么垃圾回收机制会自动回收该对象所占用的内存,不考虑该对象还存在于 WeakSet 之中 这个特点意味着,无法引用 WeakSet 的成员,因此 WeakSet

    42020

    使用 Set 检测 JavaScript 对象值的变化

    JavaScript集合是一组有序的唯一值,对于消除重复值非常有帮助。在处理离散数据时,集合是必不可少的。...let user = { name: "Ygritte Snow", married: true, home: "Winterfell" };但是我们的JavaScript如何检测到对象文字的值已更改呢...这是我们将要做的:将Ygritte结婚前和结婚后的对象值转换为可迭代的内容,即2个数组,使用Object.values()方法。使用展开运算符合并这两个数组。...创建一个合并后数组的集合以及一个初始对象的集合。比较结婚前集合和合并集合的大小。...然后我们使用Set的size属性比较了结婚前集合(结婚前对象的值)和合并集合(结婚前和结婚后对象的值)。通常我们将对象文字的值转换为数组,然后将数组转换为集合。

    20800

    JavaScript中的数据结构-Set与Map

    在 JavaScript 开发中,数据结构就像是建筑师手中的工具,它们是我们构建高效、稳固且逻辑严密的程序的基石,在ES6中,JavaScript引入了两种新的数据结构Set和Map。...这两个对象提供了更高效的方式来存储和处理数据,它们在处理大量数据时比传统的数组或对象更加灵活和强大。SetSet 是一种独特的数据结构,它的核心特点是存储唯一的值。...这意味着在一个 Set 中,不会存在重复的元素。原理:Set 内部通过某种哈希算法来确保元素的唯一性和快速查找。...(Array.from(uniqueWords)); // 输出 ["apple", "banana", "orange"]数组去重假设我们有一个包含重复项的数组,我们希望去除这些重复项,得到一个由唯一值组成的数组.../ 输出:falseMapMap 则是一种键值对的数据结构,与普通的对象不同,Map 的键可以是任何类型的值,包括对象。

    12320

    带你入门 JavaScript ES6 (五) 集合

    (sLang)// Set {"javascript", "java", "c++", "php"} 对比数组 nums 和集合 sLang,数组可以加入重复数据,而集合的所有元素是唯一的不允许重复。...(l); } 三、 WeakSet 集合 WeakSet 和 普通的 Set 相似,不同点在于: WeakSet 只能添加对象元素 WeakSet 无法迭代 没有 clear() 方法 为什么没有 clear...方法,阮一峰老师的 ES6 教程中有过解释: WeakSet 中的对象都是弱引用,即垃圾回收机制不考虑 WeakSet 对该对象的引用,也就是说,如果其他对象都不再引用该对象,那么垃圾回收机制会自动回收该对象所占用的内存...WeakSet 里面的引用,都不计入垃圾回收机制,所以就不存在这个问题。因此,WeakSet 适合临时存放一组对象,以及存放跟对象绑定的信息。...参考资料 Set 对象 WeakSet 对象 Set 和 Map 数据结构

    62720

    JavaScript ES6 (五) – 集合

    (sLang)// Set {"javascript", "java", "c++", "php"} 对比数组 nums 和集合 sLang,数组可以加入重复数据,而集合的所有元素是唯一的不允许重复。...(l); } 三、 WeakSet 集合 WeakSet 和 普通的 Set 相似,不同点在于: WeakSet 只能添加对象元素 WeakSet 无法迭代 没有 clear() 方法 为什么没有 clear...方法,阮一峰老师的 ES6 教程中有过解释: WeakSet 中的对象都是弱引用,即垃圾回收机制不考虑 WeakSet 对该对象的引用,也就是说,如果其他对象都不再引用该对象,那么垃圾回收机制会自动回收该对象所占用的内存...WeakSet 里面的引用,都不计入垃圾回收机制,所以就不存在这个问题。因此,WeakSet 适合临时存放一组对象,以及存放跟对象绑定的信息。...参考资料 Set 对象 WeakSet 对象 Set 和 Map 数据结构

    80510

    Javascript中的数组对象排序(转载)

    二、数组对象排序 如果数组项是对象,我们需要根据数组项的某个属性对数组进行排序,要怎么办呢?...Js数组排序函数sort()介绍 JavaScript实现多维数组、对象数组排序,其实用的就是原生的sort()方法,用于对数组的元素进行排序。 sort() 方法用于对数组的元素进行排序。...而我们的对象数组排序,实际上原理也是一样的。...对于对象数组排序,我们先写一个构造比较函数的函数: //by函数接受一个成员名字符串做为参数 //并返回一个可以用来对包含该成员的对象数组进行排序的比较函数 var by = function(name...//by函数接受一个成员名字符串和一个可选的次要比较函数做为参数 //并返回一个可以用来包含该成员的对象数组进行排序的比较函数 //当o[age] 和 p[age] 相等时,次要比较函数被用来决出高下

    7.9K20

    盘点JavaScript哪些常用的数组对象

    回顾 上一篇中我们盘点了 js 哪些最常用的内置对象,对Math、random以及Date对象进行了详细的讲解,这三个对象在往后的工作中也是发挥着举足轻重的位置,都是非常常用的对象,可以自己在编辑器中多加练习...这篇中我们对 js 中的数组对象进行说明,同样数组对象中也包含了非常多的元素方法,对数组的处理也扮演很重要的角色。...数组对象(Array) 在前端中数组和字符串是处理信息最常用的两种方式,所以对于数组和字符串的内置方法也需要烂熟于心。...push() 在数组的末尾 添加一个或多个数组元素 push是可以在数组末尾追加新的元素 push() 参数可以直接写数组元素就可以 push完毕之后 返回的结果是新数组长度 原数组也会发生变化...// 1, 2, 3, 4 复制代码 数组排序 除了上述这些数组中添加或者删除元素之后,数组对象中还内置了更为好玩的方法。

    2K20

    深入浅出 JavaScript 弱引用

    在 ES6 版本中,JavaScript 引入了 WeakSet 和 WeakMap。 1. 弱引用 与强引用不同,弱引用并不阻止被引用的对象被垃圾收集器回收或收集,即使它是内存中对对象的唯一引用。...: // 长度为 1 的对象数组 [{…}] 由于 human 数组和对象之间存在强引用。...Set VS WeakSet set 对象是一个只有一次出现的唯一值的集合。像数组一样,集合没有键值对。我们可以使用for...of和 .forEach 的数组方法遍历。...以下是 WeakSet() 的特性: 它可能只包含对象。 集合中的对象可以在其他地方访问。 它不能循环遍历。 像 Set() 一样,WeakSet() 有 add、has 和 delete 方法。...当数据结构在内存中时,数据结构的属性被认为是可访问的,并且它们通常保存在内存中。

    82410

    了解JavaScript弱引用与垃圾回收

    WeakSet和WeakMap是在ES6版本中被引入JavaScript的。 弱引用 澄清一下,与强引用不同,弱引用不会阻止被引用的对象被垃圾回收器回收,即使它是内存中对该对象的唯一引用。...在进入强引用、WeakSet、Set、WeakMap和Map介绍之前,让我们用下面的片段来说明弱引用。 // 创建一个WeakMap对象的实例。...比较Set和WeakSet 一个集合对象是一个唯一值的集合,只有一次出现的机会。一个集合,像一个数组一样,没有键值对。我们可以用数组方法for...of和.forEach来迭代一个数组。...以下是WeakSet()的属性: 它可能只包含对象。 集内的对象可以在其他地方到达。 它不能被循环使用。 像Set()一样,WeakSet()有 add, has, 和 delete的方法。...当数据结构在内存中时,数据结构的属性被认为是可达的,而且它们通常被保存在内存中。如果我们将一个对象存储在一个数组中,那么只要数组在内存中,即使该对象没有其他的引用,仍然可以被访问。

    1.5K104

    野生前端的数据结构基础练习(6)——集合

    网上的相关教程非常多,基础知识自行搜索即可。 习题主要选自Orelly出版的《数据结构与算法javascript描述》一书。...2.修改Set类,将存储方式从数组替换为链表,并写一段代码测试该修改。 3.为Set类增加一个higher(element)方法,该方法返回比传入元素大的元素中最小的一个,并写一段代码来测试该功能。...ES6新特性 阮一峰的ES6教程:http://es6.ruanyifeng.com/#docs/set-map ES6中原生实现了Set,Map,WeakSet,WeakMap跟集合相关的类型,和数据结构中的集合不完全一致...1.数组去重 借助集合可以实现js中最简洁的数组去重方式: //实现了Iterable接口的数据结构都可以作为初始化Set的参数 cosnt uniqueArr = [...new Set(arr)];...b.has(a))); 4.WeakSet WeakSet的成员变量只能是对象,被放入其中的对象都是弱引用,在其他引用都解除后,垃圾回收机制不会考虑WeakSet对该对象的持有。

    52830

    认识Set和Map数据结构

    Set的概念 Set是ES6提供的一种新的数据结构,它允许你存储任何类型的值,但是值是唯一的,彼此之间出现重复的情况。 Set 本身是一个构造函数,用来生成Set数据结构的。...Set的参数可以是数组或是具有iterable接口的其他数据结构来作为初始化。...Set的应用 根据Set结构中的值唯一的特点,可以很好的实现数组的去重 [...new Set([1,2,3,4,3,2])]; //[1,2,3,4] 使用Set可以很容易实现交集、并集和差集 let...s2.has(item)));// Set { 1, 4 } WeakSet WeakSet 与 Set的结构类似,但是有两点不同: WeakSet的成员只能是对象 WeakSet中的对象是弱引用Map...JavaScript 的对象(Object),本质上是键值对的集合(Hash 结构),但是传统上只能用字符串当作键。

    81970

    JavaScript 判断空对象、空数组的方法

    二、判定空数组的方法 分析:所谓空数组,就是数组的长度等于0。所以我们的难点就落在了怎么判断一个参数的数据类型是数组了。 我们可以通过isPrototypeOf()方法实现。...所以,完整的检验空数组的表达式如下: // 满足以下判断表达式的都是 空数组 [] Array.prototype.isPrototypeOf(obj) && obj.length === 0 三、判定空对象的方法...(obj) && Object.keys(obj).length === 0 其中,Object.keys()方法会返回一个由给定对象的自身可枚举属性组成的数组,数组中属性名的排列顺序和使用 for.....中一切皆是对象,也就是说,Object 也存在于数组的原型链上,因此在封装校验方法时,数组需要先于对象检验。...四、一个判断参数为空的函数封装 结合上面的空对象、空数组检测方法,我们可以封装一个判断参数为空的函数。

    29.9K43

    3种JavaScript 对象转数组的方法

    来源 | https://www.fly63.com 我们在项目开发的时候,有时需要将js对象转换为数组,下面小编给大家具体演示一下怎么转换,主要是介绍一些常用、简洁的转换方法。...比如JavaScript对象如下: let obj = { 'name': '前端', 'url': 'https://www.webadkf.com', 'des': '专注web前端开发...()方法返回一个给定对象自身的所有可枚举属性值的数组,值的顺序与使用for…in循环的顺序相同 ( 区别在于 for-in 循环枚举原型链中的属性 )。...let arr = Object.values(obj); //对象转化为数组 ps:如果只需要返回键作为数组,可以使用Object.keys()的方式,所以结合Map,也可以实现: let arr=...arr = []; //定义数组 for (var i in obj) { arr.push(obj[i]); } 方式三:Array.from Array.from() 方法对一个类似数组或可迭代对象创建一个新的

    2.1K20
    领券