码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2019-06-07 01:02:16      阅读:293      评论:0      收藏:0      [点我收藏+]

标签:结果   ide   als   foreach   use   mic   cto   分享   属性   

写在前面

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

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

1. in

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

2. hasOwnProperty

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

3. for...in

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

4. for...of

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

5. forEach

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

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

机智如我。??

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); // 报错,无可遍历接口

输出结果:
技术图片

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

标签:结果   ide   als   foreach   use   mic   cto   分享   属性   

原文地址:https://www.cnblogs.com/looyulong/p/10987180.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!