Исключение совпадающих ключей объекта

JavaScriptJavaScriptBeginner
Практиковаться сейчас

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

💡 Этот учебник переведен с английского с помощью ИИ. Чтобы просмотреть оригинал, вы можете перейти на английский оригинал

Введение

В этом практическом занятии мы изучим концепцию удаления ключей объекта на основе заданного условия с использованием JavaScript. Мы узнаем, как использовать функцию omitBy() для фильтрации ключей из объекта на основе предоставленной функции. С помощью практических примеров мы поймем, как эта функция может быть полезна для упрощения нашего кода и повышения его эффективности.


Skills Graph

%%%%{init: {'theme':'neutral'}}%%%% flowchart RL javascript(("JavaScript")) -.-> javascript/AdvancedConceptsGroup(["Advanced Concepts"]) javascript(("JavaScript")) -.-> javascript/BasicConceptsGroup(["Basic 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-28528{{"Исключение совпадающих ключей объекта"}} javascript/data_types -.-> lab-28528{{"Исключение совпадающих ключей объекта"}} javascript/arith_ops -.-> lab-28528{{"Исключение совпадающих ключей объекта"}} javascript/comp_ops -.-> lab-28528{{"Исключение совпадающих ключей объекта"}} javascript/array_methods -.-> lab-28528{{"Исключение совпадающих ключей объекта"}} javascript/higher_funcs -.-> lab-28528{{"Исключение совпадающих ключей объекта"}} javascript/destr_assign -.-> lab-28528{{"Исключение совпадающих ключей объекта"}} end

Удаление ключей объекта на основе обратного вызова функции

Для удаления ключей объекта на основе обратного вызова функции используйте функцию omitBy.

  • omitBy создает объект, состоящий из свойств, которые возвращают ложное значение для заданной функции.
  • Object.keys() и Array.prototype.filter() используются для удаления ключей, для которых fn возвращает истинное значение.
  • Array.prototype.reduce() преобразует отфильтрованные ключи обратно в объект с соответствующими парами ключ-значение.
  • Функция обратного вызова принимает два аргумента: value и key.
  • В следующем примере показано, как omitBy используется для удаления числовых ключей из объекта.
const omitBy = (obj, fn) =>
  Object.keys(obj)
    .filter((k) => !fn(obj[k], k))
    .reduce((acc, key) => ((acc[key] = obj[key]), acc), {});

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

Резюме

Поздравляем! Вы завершили практическое занятие по удалению совпадающих ключей объекта. Вы можете выполнить больше практических заданий в LabEx, чтобы улучшить свои навыки.