
本文详细介绍了在J*aScript中,如何利用`Object.entries()`、`Array.prototype.filter()`和`Object.fromEntries()`这三个现代J*aScript特性,从一个现有对象中高效且优雅地提取出指定的一组属性,生成一个新的对象。文章涵盖了从准备待提取属性列表到最终生成目标对象的完整流程,并提供了清晰的代码示例及使用注意事项。
在J*aScript开发中,我们经常需要从一个包含多个属性的对象中,只挑选出其中一部分属性来创建一个新的对象。这种场景在处理API响应、配置对象或数据转换时尤为常见。本文将介绍一种简洁且符合现代J*aScript风格的方法来实现这一目标。
实现对象属性提取的关键在于以下三个J*aScript内置方法的组合使用:
通过这三个方法的协同工作,我们可以将对象的属性列表化,筛选出目标属性,然后再重新组装成一个新的对象。
假设我们有一个源对象 someObject,以及一个包含我们希望提取的属性名的列表 propertiesToExtract。

首先,我们需要确保待提取的属性列表是一个数组。如果它最初是一个以逗号分隔的字符串,我们需要将其转换为数组。
const someObject = { number: '1', month: 'march', year: '2025', day: '15' };
// 情况一:属性列表已经是数组
const propertiesToExtractArray = ['month', 'year'];
// 情况二:属性列表是字符串,需要转换为数组
const propertiesToExtractString = 'month, year';
const propertiesToExtractFromString = propertiesToExtractString.split(', ');
console.log(propertiesToExtractFromString); // 输出: ['month', 'year']在实际应用中,通常会统一将输入处理为数组形式,以确保后续逻辑的一致性。
ChatGPT Writer
免费 Chrome 扩展程序,使用 ChatGPT AI 生成电子邮件和消息。
106
查看详情
使用 Object.entries() 方法将源对象转换为一个包含所有键值对的数组。
const entries = Object.entries(someObject); console.log(entries); // 输出: [ // ['number', '1'], // ['month', 'march'], // ['year', '2025'], // ['day', '15'] // ]
接下来,使用 filter() 方法遍历 entries 数组,只保留那些键名存在于 propertiesToExtract 列表中的键值对。
const filteredEntries = entries.filter(([key, value]) => propertiesToExtractArray.includes(key)); console.log(filteredEntries); // 输出: [ // ['month', 'march'], // ['year', '2025'] // ]
这里,([key, value]) 是数组解构赋值,方便我们直接访问当前迭代的键和值。propertiesToExtractArray.includes(key) 则判断当前键是否在我们预期的列表中。
最后,使用 Object.fromEntries() 方法将过滤后的键值对数组转换回一个新的对象。
const finalObject = Object.fromEntries(filteredEntries);
console.log(finalObject); // 输出: { month: 'march', year: '2025' }将上述步骤整合在一起,我们可以得到一个简洁高效的解决方案:
/**
* 从源对象中提取指定属性,生成一个新对象。
* @param {object} sourceObject - 源对象。
* @param {string[]|string} propertiesToExtract - 待提取的属性名列表,可以是数组或逗号分隔的字符串。
* @returns {object} 包含指定属性的新对象。
*/
function extractProperties(sourceObject, propertiesToExtract) {
let keysToExtract;
// 确保待提取属性列表是数组
if (typeof propertiesToExtract === 'string') {
keysToExtract = propertiesToExtract.split(', ').map(key => key.trim());
} else if (Array.isArray(propertiesToExtract)) {
keysToExtract = propertiesToExtract;
} else {
console.warn("propertiesToExtract 参数类型不正确,应为字符串或数组。");
return {};
}
// 使用 Object.entries, filter 和 Object.fromEntries 组合操作
const finalObject = Object.fromEntries(
Object.entries(sourceObject).filter(([key, value]) =>
keysToExtract.includes(key)
)
);
return finalObject;
}
// 示例用法
const someObject = { number: '1', month: 'march', year: '2025', day: '15' };
// 提取 'month' 和 'year'
const result1 = extractProperties(someObject, ['month', 'year']);
console.log('提取数组属性:', result1); // 输出: { month: 'march', year: '2025' }
// 提取 'number' 和 'day' (使用字符串形式)
const result2 = extractProperties(someObject, 'number, day');
console.log('提取字符串属性:', result2); // 输出: { number: '1', day: '15' }
// 提取不存在的属性
const result3 = extractProperties(someObject, ['foo', 'bar']);
console.log('提取不存在属性:', result3); // 输出: {}
// 提取所有属性 (通过将所有key都包含在列表中实现)
const allKeys = Object.keys(someObject);
const result4 = extractProperties(someObject, allKeys);
console.log('提取所有属性:', result4); // 输出: { number: '1', month: 'march', year: '2025', day: '15' }利用 Object.entries()、Array.prototype.filter() 和 Object.fromEntries() 的组合,我们可以在J*aScript中以一种声明式、高效且易读的方式从对象中提取指定属性。这种模式是现代J*aScript开发中处理对象属性的推荐实践,它不仅提升了代码的简洁性,也遵循了不可变性原则,使得数据操作更加安全可靠。掌握这一技巧,将有助于你编写出更健壮、更优雅的J*aScript代码。
以上就是J*aScript中如何高效提取对象指定属性的详细内容,更多请关注其它相关文章!
相关文章:
Golang如何使用new_Go new分配内存机制讲解
Python模块化编程:有效管理依赖与避免循环引用
poki网页游戏推荐_poki免费游戏平台入口
TikTok搜索结果不显示如何解决 TikTok搜索刷新优化方法
拼多多购物车商品数量无法修改如何处理 拼多多购物车操作优化方法
怎么在mac上运行html代码_mac运行html代码方法【指南】
钉钉视频会议画面卡顿如何解决 钉钉会议画面优化方法
C++如何检测键盘输入_C++ _kbhit与_getch函数非阻塞输入
微信网页版官方入口教程 微信网页版网页版快速登录步骤
智慧团建扫码登录入口 智慧团建扫码登录入口官网版
Angular响应式表单:实现提交后表单及按钮的禁用与只读化
Django通过AJAX异步上传图片并保存至模型的完整指南
HTML长属性值处理:表单action路径优化与代码规范应对
Lar*el Excel导入时生成自定义递增ID的策略与实践
企业名称高精度匹配:N-gram方法在结构相似性分析中的应用
在PHP脚本中通过SSHFS挂载远程文件系统的最佳实践与常见问题解决
Fabric Mod开发:在1.19.3+版本中正确添加自定义物品并管理物品组
Python中高效且防溢出的双曲正弦计算:基于对数空间的优化策略
在J*a中如何捕获IndexOutOfBoundsException_索引越界异常防护方法说明
Yandex搜索引擎官方地址 俄罗斯网络世界的主要入口
漫蛙manwa官网登录界面_漫蛙漫画网页版主站入口
抖音DOU+怎么投最有效 抖音付费推广的ROI提升技巧
Win10怎么设置静态IP地址 Win10手动配置IP地址步骤【指南】
Excel文件在线转换快速入口 Excel在线格式转换网站
Pygame教程:解决用户输入与游戏状态更新不同步问题
生成rdflib自定义SPARQL函数:参数匹配与实践指南
css子元素高度不一致导致布局错位怎么办_使用align-items:stretch解决高度差异
Python字典中优雅地迭代剩余元素的方法
怎么去除衣服上的口红印_生活小妙招教你用酒精轻松擦除
汽水音乐网页版使用入口_汽水音乐电脑版播放指南
京东京造J1和网易云音乐氧气真无线有什么不同_国产电商蓝牙耳机音质对比
win11如何卸载Windows更新补丁 Win11解决更新导致系统不稳定的问题【修复】
PHP 枚举:根据字符串获取枚举案例的策略与实现
Python大型XML文件高效流式解析教程
Excel中VLOOKUP的第四个参数是干什么用的_Excel VLOOKUP第四参数作用解析
极速漫画官方主页网址 极速漫画漫画在线浏览官网链接
qq邮箱发邮件给国外发不出去_QQ邮箱国际邮件发送失败原因与解决
QQ官网正版登录链接 QQ在线登录入口最新
win11开机启动修复循环怎么办 Win11无法进入系统高级启动解决方法【修复】
Windows电脑怎么截图最方便_系统自带截图工具的5种神仙用法【技巧】
Go语言中JSON数据解析与字段访问教程
小红书怎么解除第三方平台绑定_小红书多平台登录解绑方法介绍
C++20的source_location是什么_C++在编译期获取源码位置信息用于日志和断言
Win11怎么安装Linux子系统 Win11 WSL2安装Ubuntu及环境配置指南
J*aScript DOM操作:高效清空列表元素的策略与实践
qq音乐在线播放入口_qq音乐电脑版登录链接
CSS自定义字体样式被系统字体替换怎么办_font-face方式指定font-display控制渲染策略
Sublime怎么配置Nim语言环境_Sublime Nim代码高亮与补全
Pandas DataFrame 多条件优先级排序与排名
c++中的std::basic_string的SSO优化_c++短字符串优化深度解析