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

Python 数据库优化与性能调优
Python 数据库优化与性能调优

本专题专注讲解 Python 在数据库性能优化中的应用,包括数据库连接池管理、SQL 查询优化、索引设计与使用、数据库事务管理、分布式数据库与缓存系统的结合。通过分析常见性能瓶颈,帮助开发者掌握 如何优化数据库操作,提升 Python 项目在数据库层的响应速度与处理能力。

0

2026.02.05

Java 微服务与 Spring Cloud 实战
Java 微服务与 Spring Cloud 实战

本专题讲解 Java 微服务架构的开发与实践,重点使用 Spring Cloud 实现服务注册与发现、负载均衡、熔断与限流、分布式配置管理、API Gateway 和消息队列。通过实际项目案例,帮助开发者理解 如何将传统单体应用拆分为高可用、可扩展的微服务架构,并有效管理和调度分布式系统中的各个组件。

0

2026.02.05

C++ 多线程编程与线程池设计
C++ 多线程编程与线程池设计

本专题深入讲解 C++ 中的多线程编程与线程池设计,涵盖 C++11/14/17 的线程库、线程同步机制(mutex、condition_variable、atomic)、线程池设计模式、任务调度与优化、并发瓶颈分析与解决方案。通过多个实际案例,帮助开发者掌握 如何设计高效的线程池管理系统,提升 C++ 程序在高并发场景下的性能与稳定性。

0

2026.02.05

微信网页版文件传输助手教程合集
微信网页版文件传输助手教程合集

本专题整合了微信网页版文件传输助手教程、入口等等内容,阅读专题下面的文章了解更多详细内容。

15

2026.02.04

微信文件过期恢复教程
微信文件过期恢复教程

本专题整合了微信文件过期恢复方法、技巧教程,阅读专题下面的文章了解更多详细内容。

10

2026.02.04

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
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号