选取匹配的对象键

JavaScriptJavaScriptBeginner
立即练习

This tutorial is from open-source community. Access the source code

💡 本教程由 AI 辅助翻译自英文原版。如需查看原文,您可以 切换至英文原版

简介

在本实验中,我们将探索如何使用 pickBy() 函数来创建一个新对象,该对象仅由给定函数返回真值的键值对组成。在需要根据特定标准从对象中过滤掉某些属性的场景中,此函数可能会很有用。我们将学习如何使用 Object.keys()Array.prototype.filter()Array.prototype.reduce() 来完成此任务。


Skills Graph

%%%%{init: {'theme':'neutral'}}%%%% flowchart RL javascript(("JavaScript")) -.-> javascript/BasicConceptsGroup(["Basic Concepts"]) javascript(("JavaScript")) -.-> javascript/AdvancedConceptsGroup(["Advanced Concepts"]) javascript/BasicConceptsGroup -.-> javascript/variables("Variables") javascript/BasicConceptsGroup -.-> javascript/data_types("Data Types") javascript/BasicConceptsGroup -.-> javascript/arith_ops("Arithmetic Operators") javascript/BasicConceptsGroup -.-> javascript/comp_ops("Comparison Operators") javascript/BasicConceptsGroup -.-> javascript/array_methods("Array Methods") javascript/AdvancedConceptsGroup -.-> javascript/higher_funcs("Higher-Order Functions") javascript/AdvancedConceptsGroup -.-> javascript/destr_assign("Destructuring Assignment") subgraph Lab Skills javascript/variables -.-> lab-28543{{"选取匹配的对象键"}} javascript/data_types -.-> lab-28543{{"选取匹配的对象键"}} javascript/arith_ops -.-> lab-28543{{"选取匹配的对象键"}} javascript/comp_ops -.-> lab-28543{{"选取匹配的对象键"}} javascript/array_methods -.-> lab-28543{{"选取匹配的对象键"}} javascript/higher_funcs -.-> lab-28543{{"选取匹配的对象键"}} javascript/destr_assign -.-> lab-28543{{"选取匹配的对象键"}} end

选取符合给定条件的对象键的函数

要选取符合给定条件的对象键,请使用 pickBy() 函数。此函数会创建一个新对象,该对象由给定函数返回真值的属性组成。

  • 使用 Object.keys()Array.prototype.filter() 来移除 fn 返回假值的键。
  • 使用 Array.prototype.reduce() 将过滤后的键转换回具有相应键值对的对象。
  • 回调函数会使用两个参数调用:(值,键)。

以下是 pickBy() 函数的代码:

const pickBy = (obj, fn) =>
  Object.keys(obj)
    .filter((k) => fn(obj[k], k))
    .reduce((acc, key) => ((acc[key] = obj[key]), acc), {});

你可以使用此函数来选取符合条件的键。例如:

pickBy({ a: 1, b: "2", c: 3 }, (x) => typeof x === "number");
// { 'a': 1, 'c': 3 }

总结

恭喜你!你已经完成了“选取匹配的对象键”实验。你可以在 LabEx 中练习更多实验来提升你的技能。