Назад к вопросам
Junior
195
questionbank

С какими нововведениями в ES6 вы знакомы?

Sobes Copilot

Получайте ответы в реальном времени

Ответ от нейросети

sobes.tech AI

  • let, const, var: let и const для блочной области видимости, var для функциональной. const для констант, let для переменных, которые могут переназначаться.
  • Стрелочные функции (Arrow Functions): Сокращенный синтаксис для объявления функций. Lexical this.
  • Шаблонные литералы (Template Literals): Позволяют встраивать выражения и многострочные строки.
    const name = "World";
    const greeting = `Hello, ${name}!`; // "Hello, World!"
    
  • Деструктурирующее присваивание (Destructuring Assignment): Удобный способ извлечения значений из массивов и объектов.
    const person = { firstName: "John", lastName: "Doe" };
    const { firstName, lastName } = person; // firstName = "John", lastName = "Doe"
    
  • Spread-оператор (...) и Rest parameters (...): Spread для расширения и объединения массивов/объектов. Rest для сбора оставшихся аргументов функции в массив.
    const arr1 = [1, 2];
    const arr2 = [...arr1, 3, 4]; // [1, 2, 3, 4]
    
    function sum(...numbers) {
      return numbers.reduce((acc, current) => acc + current, 0);
    }
    sum(1, 2, 3); // 6
    
  • Классы (Classes): Синтаксический сахар над прототипным наследованием.
    class Car {
      constructor(brand) {
        this.brand = brand;
      }
      drive() {
        console.log(`${this.brand} is driving.`);
      }
    }
    
  • Модули (Modules): Средство для организации кода с помощью import и export.
    // module.js
    export const PI = 3.14;
    
    // main.js
    import { PI } from './module.js';
    
  • Промисы (Promises): Упрощают работу с асинхронным кодом.
    new Promise((resolve, reject) => {
      // Асинхронная операция
      if (success) {
        resolve("Успех!");
      } else {
        reject("Ошибка!");
      }
    })
    .then(result => console.log(result))
    .catch(error => console.error(error));
    
  • for...of цикл: Итерация по итерируемым объектам (массивы, строки, Map, Set, etc.).
    const arr = [1, 2, 3];
    for (const value of arr) {
      console.log(value); // 1, 2, 3
    }
    
  • Set и Map: Новые структуры данных. Set для уникальных значений, Map для пар ключ-значение.