参考链接:https://segmentfault.com/a/1190000041418203
tips: D3.js 画图表 + SVG 的 feDisplacementMap 滤镜实现手绘特效
lodash pick function
const newObj = _.pick(obj, [keyA, keyB])
所以 for-in 更适合遍历对象,不要使用for in遍历数组。
for-in 遍历的是数组的索引(即键名),而for of遍历的是数组元素值。
for-of 遍历的只是数组内的元素,而不包括数组的原型属性method和索引name
for in 可以遍历到myObject的原型方法method,如果不想遍历原型方法和属性的话,可以在循环内部判断一下,hasOwnPropery方法可以判断某属性是否是该对象的实例属性
同样可以通过ES5的Object.keys(myObject)获取对象的实例属性组成的数组,不包括原型方法和属性
for..of适用遍历数/数组对象/字符串/map/set等拥有迭代器对象的集合.但是不能遍历对象,因为没有迭代器对象.与forEach()不同的是,它可以正确响应break、continue和return语句
主要利用 WeakMap(弱映射)的 “不可迭代键” 特性实现
基于上述特性,可以实现真正的私有变量的一种新方式,前提很明确,私有变量会存储在 WeakMap 中,以对象实例为键,以私有成员的字典为值。
通过闭包,维护一个 WeakMap 集合,维护私有变量
1 | const User = (() => { |