巧记 In/hasOwnProperty/for…in/for…of/forEach区别

写在前面

上面提到的这些东西,反复的记忆,反复的忘记。现分享一种巧记方法,有须要,请参考,但愿你也过目不忘。javascript

仅提供巧记思路。仅提供巧记思路。仅提供巧记思路。java

1. in

用于判断属性是否在对象上(包括继承而来的原型)。(小孩才作选择,我全要^_^)
经过in的英文意思,这个不可能记混淆。node

2. hasOwnProperty

用于判断属性是否为自身属性(仅仅自身,不包括继承而来的)。
经过own的英文意思,这个也不可能混淆数组

3. for...in

根据1中提到的in记忆。这个是用来遍历对象的,且连原型上的属性也包括。
若是做用在数组上,则把其当作对象来对待。ide

4. for...of

已经有了个兄弟(for...in)用来遍历对象,为了公平起见,ES2016“憋出”个用来遍历数组的东西。函数

5. forEach

这家伙与map、reduce、filter之类的都是ES2015新增内容。联想起来,它做用于数组,且回调函数的参数为(value, key)这种顺序。初略来看,一个数组中value的意义高于key的意义,因此有了这样的顺序。this

6. 这样一来,这些东西就不会搞混淆了。

机智如我。😜code

7. 接下来写个demo加深印象,之后碰到绝对不会忘记、混淆了。

// node 环境跑一下试试

function divider(title) {
  console.log("--------------------");
  console.log(`${title}`);
}

function forIn(data) {
  for (value in data) {
    console.log(`for value in [${data.toString()}] : value = `, value);
  }
}

function forOf(data) {
  for (value of data) {
    console.log(`for value of [${data.toString()}] : value = `, value);
  }
}

function useIn(data, target) {
  console.log(`${data} in [${target.toString()}] : `, data in target);
}

class Obj {
  constructor() {
    this.bar = 345; // 实例属性
    this.__proto__.foo = 123; // 原型属性
  }
}

const obj = new Obj();
const arr = ["a", "b"];

divider("for in 遍历对象");
forIn(obj); // bar foo

divider("for in 遍历数组");
forIn(arr); // 0 1

divider("in 做用于对象");
useIn("foo", obj); // true
useIn("bar", obj); // true

divider("in 做用于数组");
useIn("a", arr); // false
useIn("b", arr); // false
useIn(1, arr); // true

divider("for of 遍历数组");
forOf(arr); // a, b
divider("for of 遍历对象");
forOf(obj); // 报错,无可遍历接口

输出结果:
对象

相关文章
相关标签/搜索