遍历对象属性

这篇博客的灵感来自于牛客网的一道题:属性遍历

题目描述:
找出对象 obj 不在原型链上的属性(注意这题测试例子的冒号后面也有一个空格~)
1、返回数组,格式为 key: value
2、结果数组不要求顺序

1. for in

  • for-in会漏掉不可枚举属性;
  • for-in会遍历原型链上的属性,需要配合hasOwnProperty过滤
function iterate(obj) {
    // hasOwnProperty
    // 如果使用for in遍历,很重要的一点是不能遍历的自身属性会被遗漏
    var result = [];
    for(var p in obj){
		if(obj.hasOwnProperty(p)){
			result.push(p + ": " + obj[p]);
		}
	}
	return result;
}

2. Object.keys()

  • 返回对象自身的可枚举属性
function iterate(obj) {
    return Object.keys(obj);
    return result.map(n => n + ": " + obj[n]);
}

3. Object.getOwnPropertyNames()

  • 返回自身的所有属性,含不可枚举属性
// 从题目要求来看,这才是正解
function iterate(obj) {
    // 如果使用for in遍历和 Object.keys,很重要的一点是不能遍历的自身属性会被遗漏
    var names = Object.getOwnPropertyNames(obj);
    return  names.map(function(n){return n + ": " + obj[n]});
}