Найти первый соответствующий ключ

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

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

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

Введение

В этом лабораторном задании мы исследуем реализацию JavaScript-функции под названием findKey. Эта функция предназначена для поиска первого ключа в объекте, который удовлетворяет заданной тестирующей функции. Используя Object.keys() и Array.prototype.find(), мы можем эффективно искать среди свойств объекта и вернуть нужный ключ.


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/destr_assign("Destructuring Assignment") subgraph Lab Skills javascript/variables -.-> lab-28302{{"Найти первый соответствующий ключ"}} javascript/data_types -.-> lab-28302{{"Найти первый соответствующий ключ"}} javascript/arith_ops -.-> lab-28302{{"Найти первый соответствующий ключ"}} javascript/comp_ops -.-> lab-28302{{"Найти первый соответствующий ключ"}} javascript/array_methods -.-> lab-28302{{"Найти первый соответствующий ключ"}} javascript/destr_assign -.-> lab-28302{{"Найти первый соответствующий ключ"}} end

Функция для поиска первого ключа, соответствующего тесту

Для поиска первого ключа в объекте, который соответствует заданной тестовой функции, используйте функцию findKey(). Сначала получите все свойства объекта с помощью Object.keys(). Затем примените тестовую функцию к каждой паре ключ-значение с использованием Array.prototype.find(). Тестовая функция должна принимать три аргумента: значение, ключ и объект. Функция возвращает первый ключ, который удовлетворяет тестовой функции, или undefined, если не найдено ни одного.

Вот пример реализации findKey():

const findKey = (obj, fn) =>
  Object.keys(obj).find((key) => fn(obj[key], key, obj));

Для использования findKey() передайте объект и тестовую функцию в качестве аргументов:

findKey(
  {
    barney: { age: 36, active: true },
    fred: { age: 40, active: false },
    pebbles: { age: 1, active: true }
  },
  (x) => x["active"]
); // 'barney'

В этом примере findKey() возвращает первый ключ в объекте, где значение свойства active равно true, что является 'barney'.

Резюме

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