Files
freeCodeCamp/curriculum/challenges/ukrainian/02-javascript-algorithms-and-data-structures/es6/use-destructuring-assignment-to-extract-values-from-objects.md
2023-01-27 17:05:47 +02:00

3.2 KiB
Raw Blame History

id, title, challengeType, forumTopicId, dashedName
id title challengeType forumTopicId dashedName
5cfa550e84205a357704ccb6 Деструктуроване присвоєння для отримання значень з об’єктів 1 301216 use-destructuring-assignment-to-extract-values-from-objects

--description--

Деструктуроване присвоєння є спеціальним синтаксисом, представленим в ES6, за допомогою якого можна акуратно присвоювати значення, взяте прямо з об’єкта.

Розглянемо наступний приклад коду ES5:

const user = { name: 'John Doe', age: 34 };

const name = user.name;
const age = user.age;

name матиме значення рядка John Doe, а age матиме значення числа 34.

Ось еквівалентна інструкція присвоєння з деструктованим синтаксисом ES6:

const { name, age } = user;

Знову ж таки, name матиме значення рядка John Doe, а age матиме значення числа 34.

Тут будуть створені змінні name та age, а також їм будуть присвоєні значення (відповідно до значень з об’єкта user). Можете помітити, наскільки почистішав код.

Ви можете отримати потрібну кількість значень з потрібного вам об’єкта.

--instructions--

Замініть два присвоєння на еквівалентні деструктуровані присвоєння. Вони досі повинні присвоювати змінним today та tomorrow значення today та tomorrow з об’єкта HIGH_TEMPERATURES.

--hints--

Ви повинні видалити синтаксис присвоєння ES5.

assert(
  !code.match(/today\s*=\s*HIGH_TEMPERATURES\.(today|tomorrow)/g)
);

Ви повинні використати деструктуризацію, щоб створити змінну today.

assert(
  code.match(/(var|let|const)\s*{\s*(today[^}]*|[^,]*,\s*today)\s*}\s*=\s*HIGH_TEMPERATURES(;|\s+|\/\/)/g)
);

Ви повинні використати деструктуризацію, щоб створити змінну tomorrow.

assert(
  code.match(/(var|let|const)\s*{\s*(tomorrow[^}]*|[^,]*,\s*tomorrow)\s*}\s*=\s*HIGH_TEMPERATURES(;|\s+|\/\/)/g)
);

today повинна дорівнювати 77, а tomorrow повинна дорівнювати 80.

assert(today === 77 && tomorrow === 80);

--seed--

--seed-contents--

const HIGH_TEMPERATURES = {
  yesterday: 75,
  today: 77,
  tomorrow: 80
};

// Only change code below this line

const today = HIGH_TEMPERATURES.today;
const tomorrow = HIGH_TEMPERATURES.tomorrow;

// Only change code above this line

--solutions--

const HIGH_TEMPERATURES = {
  yesterday: 75,
  today: 77,
  tomorrow: 80
};

const { today, tomorrow } = HIGH_TEMPERATURES;