0

0

如何从对象中提取指定值对应的所有键名并组成数组

聖光之護

聖光之護

发布时间:2026-02-05 14:35:02

|

993人浏览过

|

来源于php中文网

原创

如何从对象中提取指定值对应的所有键名并组成数组

本文介绍如何遍历 javascript 对象,精准筛选出值等于目标值的键名(或键值对),并将其收集为新数组,避免常见错误如误推整个对象或返回全部键。

在实际开发中,我们常需根据值反查对象中的匹配键。例如,给定一个记录人物胸围尺寸的对象,想找出所有胸围为 36 的人名(即键名)。但初学者容易犯一个典型错误:在循环中误将整个对象 chestSize(而非键名 key)推入数组,导致结果完全偏离预期。

来看原始代码的问题所在:

const chestSize = {
  "Leanne": 30,
  "Denise": 26,
  "Carol": 36,
  "Jill": 28,
  "Randy": 32
};

const chestSizeThirtySix = [];

for (const key in chestSize) {
  if (chestSize[key] === 36) {
    chestSizeThirtySix.push(chestSize); // ❌ 错误:推入整个对象
  }
}
console.log(chestSizeThirtySix); // 输出:[{ Leanne: 30, Denise: 26, ... }] —— 不是想要的键或键值对

正确做法是:只推送匹配的键名(key),或按需推送包含该键值对的新对象。推荐使用函数式方法 Object.entries() 配合 filter() 和 map(),语义清晰、不可变且易于复用:

塔猫ChatPPT
塔猫ChatPPT

塔猫官网提供AI一键生成 PPT的智能工具,帮助您快速制作出专业的PPT。塔猫ChatPPT让您的PPT制作更加简单高效。

下载
const chestSize = {
  "Leanne": 30,
  "Denise": 26,
  "Carol": 36,
  "Jill": 28,
  "Randy": 32
};

// ✅ 方案一:仅获取匹配的键名(字符串数组)
const keysWithValue36 = Object.entries(chestSize)
  .filter(([, value]) => value === 36)
  .map(([key]) => key);

console.log(keysWithValue36); // ["Carol"]

// ✅ 方案二:获取匹配的键值对对象数组(每个元素为 { key: value })
const entriesWithValue36 = Object.entries(chestSize)
  .filter(([, value]) => value === 36)
  .map(([key, value]) => ({ [key]: value }));

console.log(entriesWithValue36); // [{ Carol: 36 }]

⚠️ 注意事项:

  • for...in 循环需配合 hasOwnProperty() 防御原型链污染(虽本例无此风险,但属最佳实践);
  • 若需兼容旧环境(如 IE),Object.entries() 需 polyfill,或改用 Object.keys() + map() 组合;
  • 多个键可能对应同一值(如两人胸围均为 36),上述方案天然支持多匹配结果;
  • 使用严格相等 === 可避免类型隐式转换导致的意外匹配(如 36 == "36" 为 true,但通常不期望如此)。

总结:与其手动遍历+条件推送,不如利用 Object.entries() 将对象转为 [key, value] 二元组数组,再通过函数式链式操作精准筛选与映射——代码更简洁、意图更明确、维护性更高。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

75

2025.09.05

golang map相关教程
golang map相关教程

本专题整合了golang map相关教程,阅读专题下面的文章了解更多详细内容。

36

2025.11.16

golang map原理
golang map原理

本专题整合了golang map相关内容,阅读专题下面的文章了解更多详细内容。

64

2025.11.17

java判断map相关教程
java判断map相关教程

本专题整合了java判断map相关教程,阅读专题下面的文章了解更多详细内容。

42

2025.11.27

java连接字符串方法汇总
java连接字符串方法汇总

本专题整合了java连接字符串教程合集,阅读专题下面的文章了解更多详细操作。

7

2026.02.05

java中fail含义
java中fail含义

本专题整合了java中fail的含义、作用相关内容,阅读专题下面的文章了解更多详细内容。

8

2026.02.05

控制反转和依赖注入区别
控制反转和依赖注入区别

本专题整合了控制反转和依赖注入区别、解释、实现方法相关内容。阅读专题下面的文章了解更多详细教程。

10

2026.02.05

钉钉脑图插图教程合集
钉钉脑图插图教程合集

本专题整合了钉钉脑图怎么插入图片、钉钉脑图怎么用相关教程,阅读专题下面的文章了解更多详细内容。

20

2026.02.05

python截取字符串方法汇总
python截取字符串方法汇总

本专题整合了python截取字符串方法相关合集,阅读专题下面的文章了解更多详细内容。

2

2026.02.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.7万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.7万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号