【JavaScript】遍历对象属性

本文详细介绍了三种遍历JavaScript对象属性的方法:for-in循环、Object.keys()和Object.getOwnPropertyNames(),并对比了它们的特点和适用场景,强调了Object.getOwnPropertyNames()在确保遍历到对象所有属性(包括不可枚举属性)方面的优势。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

遍历对象属性

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

题目描述:
找出对象 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]});
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值