5.2 KiB
5.2 KiB
id, title, challengeType, forumTopicId, localeTitle
id | title | challengeType | forumTopicId | localeTitle |
---|---|---|---|---|
587d7b8a367417b2b2512b4e | Create Strings using Template Literals | 1 | 301200 | Создание строк с использованием шаблонных литералов |
Description
const person = {Тут произошло несколько вещей. Во-первых, в примере используются обратный штрих (
name: "Зодиак Хасбро",
age: 56
};
// Литерал шаблона с многострочной и строковой интерполяцией
const greeting = `Привет, меня зовут $ {person.name}!
Мне $ {person.age} лет. ';
console.log (greeting); // печатает
// Привет, меня зовут Асбро!
// Мне 56 лет.
`
), а не кавычки ( '
или "
), чтобы обернуть строку. Во-вторых, обратите внимание, что строка является многострочной, как в коде, так и в выводе. Это сохраняет вставку \n
внутри строк. Синтаксис ${variable}
используемый выше, является заполнителем. В принципе, вам больше не нужно будет использовать конкатенацию с оператором +
. Чтобы добавить переменные в строки, вы просто вставляете переменную в строку шаблона и оборачиваете ее ${
и }
Аналогичным образом вы можете включить другие выражения в строковый литерал, например ${a + b}
. Этот новый способ создания строк дает вам больше гибкости для создания надежных строк.
Instructions
failure
объекта result
. Каждая запись должна быть обернута внутрь элемента li
с атрибутом класса text-warning
и указана в resultDisplayArray
.
Tests
tests:
- text: <code>resultDisplayArray</code> should be an array containing <code>result failure</code> messages.
testString: assert(typeof makeList(result.failure) === 'object' && resultDisplayArray.length === 3);
- text: <code>resultDisplayArray</code> is the desired output.
testString: assert(makeList(result.failure).every((v, i) => v === `<li class="text-warning">${result.failure[i]}</li>` || v === `<li class='text-warning'>${result.failure[i]}</li>`));
- text: Template strings and expression interpolation should be used
testString: getUserInput => assert(getUserInput('index').match(/(`.*\${.*}.*`)/));
- text: An iterator should be used
testString: getUserInput => assert(getUserInput('index').match(/for|map|reduce|forEach|while/));
Challenge Seed
const result = {
success: ["max-length", "no-amd", "prefer-arrow-functions"],
failure: ["no-var", "var-on-top", "linebreak"],
skipped: ["id-blacklist", "no-dup-keys"]
};
function makeList(arr) {
"use strict";
// change code below this line
const resultDisplayArray = null;
// change code above this line
return resultDisplayArray;
}
/**
* makeList(result.failure) should return:
* [ `<li class="text-warning">no-var</li>`,
* `<li class="text-warning">var-on-top</li>`,
* `<li class="text-warning">linebreak</li>` ]
**/
const resultDisplayArray = makeList(result.failure);
Solution
const result = {
success: ["max-length", "no-amd", "prefer-arrow-functions"],
failure: ["no-var", "var-on-top", "linebreak"],
skipped: ["id-blacklist", "no-dup-keys"]
};
function makeList(arr) {
"use strict";
const resultDisplayArray = arr.map(val => `<li class="text-warning">${val}</li>`);
return resultDisplayArray;
}
/**
* makeList(result.failure) should return:
* [ `<li class="text-warning">no-var</li>`,
* `<li class="text-warning">var-on-top</li>`,
* `<li class="text-warning">linebreak</li>` ]
**/
const resultDisplayArray = makeList(result.failure);