--- id: 587d7b8a367417b2b2512b4e title: Create Strings using Template Literals challengeType: 1 forumTopicId: 301200 localeTitle: Создание строк с использованием шаблонных литералов --- ## Description
Новая функция ES6 - это шаблонный литерал . Это специальный тип строки, который упрощает создание сложных строк. Литералы шаблонов позволяют создавать многострочные строки и использовать функции интерполяции строк для создания строк. Рассмотрим следующий код:
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
```yml tests: - text: resultDisplayArray should be an array containing result failure messages. testString: assert(typeof makeList(result.failure) === 'object' && resultDisplayArray.length === 3); - text: resultDisplayArray is the desired output. testString: assert(makeList(result.failure).every((v, i) => v === `
  • ${result.failure[i]}
  • ` || v === `
  • ${result.failure[i]}
  • `)); - 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
    ```js 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: * [ `
  • no-var
  • `, * `
  • var-on-top
  • `, * `
  • linebreak
  • ` ] **/ const resultDisplayArray = makeList(result.failure); ```
    ## Solution
    ```js 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 => `
  • ${val}
  • `); return resultDisplayArray; } /** * makeList(result.failure) should return: * [ `
  • no-var
  • `, * `
  • var-on-top
  • `, * `
  • linebreak
  • ` ] **/ const resultDisplayArray = makeList(result.failure); ```