参考答案:
Map本质上是一个键值对的集合。和传统对象结构相比,传统对象只能用字符串作为键名,这在使用上造成了很大的限制。
1const data = {} 2//element为节点对象 3const element = document.querySelector('.node') 4console.log(element) //输出div.node对象 5console.log(element.toString()) 6//用点操作符不能有空格,所以采用中括号的形式给对象赋值 7data[element] = 'objectData' 8//输出objectData,说明在对象中存在[object HTMLDivElement]键名 9console.log(data['[object HTMLDivElement]']) 10
上面带代码中,我们创建了一个对象并将一个节点对象作为它的键名,并进行了代码测试,首先验证了获取到的element节点为一个对象,再确定了经过toString方法转化后的结果,以这个值为键名成功的输出了value值objectData。
上面的代码证明了传统对象的键名会通过toString方法转化为字符串类型
注意:在我们访问对象成员的时,键名有空格时不能采用点访问,例如data.ab c 这是错误的。我们可以用data['ab c']的形式访问
Map类似于对象,但是键名不限于字符串,可以说Object结构提供键值对应,Map提供值值对应,因此采用Map结构会优于传统对象。
1const dataMap = new Map() 2const element = document.querySelector('.node') 3dataMap.set(element,'objectData') 4console.log(dataMap.get(element)) 5console.log(dataMap)
上面的代码中我们获取值时直接传入了element对象,成功将对象作为键名,弥补了传统对象的不足。
WeakMap是ES6中新增的一种集合类型,叫做'弱映射'。它和Map是兄弟关系,与Map的区别在于这个弱字,API还是Map那套API
只接受对象作为键名(null除外),不接受其它类型的值作为键名。
首先我们需要知道什么是强引用什么是弱引用
强引用
1const e1 = document.getElementById('foo') 2const e2 = document.getElementById('bar') 3const arr = [ 4 [e1,'foo'], 5 [e2,'bar'], 6];
上面的代码中e1和e2是两个对象,通过arr数组对这两个对象添加一些文字说明。但是这样就形成了arr对e1和e2的引用,而这种引用又是强引用。它的区别就体现在这。当我们不再需要这两个对象时,我们必须手动删除这个引用,接触arr对两个对象的引用关系,否则垃圾回收机制不会释放e1和e2占用的内存。因为arr仍然存在着对对象的引用。
1arr[0] = null; 2arr[1] = null;
弱引用
是指不能确保其引用的对象不会被垃圾回收器回收的引用。一个对象若只被弱引用所引用,则被认为是不可访问的,并因此可能在任何时刻被回收。
也就是说当我们创建一个弱引用的对象时,我们就可以静静地等待其被垃圾回收器回收。
总的来说,局势WeakMap保持了对键名所引用对象的弱引用,即垃圾回收机制不将该引用考虑在内。只要所引用的对象的其它引用都被清除,垃圾回收机制就会释放该对象所占用的内存。也就是说,一旦不再需要,WeakMap里面的键名对象和所对应的键值对会自动消失,不需要手动删除引用。
正因为WeakMap对键名引用的对象是弱引用关系 ,因此WeakMap内部成员是会取决于垃圾回收机制有没有执行,运行前后成员个数很可能是不一样的,而垃圾回收机制的执行又是不可预测的,因此不可遍历。
最近更新时间:2024-08-10