DEV Community

Andrew
Andrew

Posted on • Updated on

Що нового в ES2022? 🤔

1. Метод .at() індексованих значень

Ця функція дозволяє нам читати елемент із заданим індексом. Він може приймати від’ємні індекси для читання елементів із кінця даного типу даних.

[1, 2, 3, 4, 5].at(3) // returns 4

[1, 2, 3, 4, 5].at(-2) // returns 4
Enter fullscreen mode Exit fullscreen mode

Типи даних, що підтримують цю функцію:

  • Рядок;
  • Масив;
  • Усі класи Typed Array: Uint8Array тощо.

2. Індекси відповідності RegExp

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

Існують різні способи зіставлення індексів.

  • Індекси відповідності для нумерованої групи
const matchObj = /(a+)(b+)/d.exec('aaaabb');

console.log(matchObj);
/*
Output -
['aaaabb', 'aaaa', 'bb', index: 0, input: 'aaaabb', groups: undefined, indices: Array(3)]
*/
Enter fullscreen mode Exit fullscreen mode

Завдяки прапору регулярного виразу /d matchObj також має властивість .indices, яка записує для кожної нумерованої групи, де вона була записана у вхідному рядку.

matchObj.indices[1];
// Output - [0, 4]
Enter fullscreen mode Exit fullscreen mode
  • Індекси відповідності для названих груп
const matchObj = /(?<as>a+)(?<bs>b+)/d.exec('aaaabb');

console.log(matchObj);
/*
Output -
['aaaabb', 'aaaa', 'bb', index: 0, input: 'aaaabb', groups: {as: 'aaaa', bs: 'bb'}, indices: Array(3)]
*/
Enter fullscreen mode Exit fullscreen mode

Їх індекси зберігаються в matchObj.indices.groups.

matchObj.indices.groups;
// Output - { as: [0,4], bs: [4,6] }
Enter fullscreen mode Exit fullscreen mode

3.Object.hasOwn(obj, propKey)

Це безпечний спосіб перевірити, чи propKey є власністю об’єкта obj. Він схожий на Object.prototype.hasOwnProperty, але підтримує всі типи об’єктів.

const proto = {
  protoProp: 'protoProp',
};

const obj = {
  __proto__: proto,
  objProp: 'objProp',
};

console.log('protoProp' in obj); // output - true
console.log(Object.hasOwn(obj, 'protoProp')) // output - false
console.log(Object.hasOwn(proto, 'protoProp')); // output - true
Enter fullscreen mode Exit fullscreen mode
  1. error.cause

Помилка та її підкласи тепер дозволяють визначити причину помилки. Це корисно в глибоко вкладених функціях, де ми зв’язали блоки помилок, щоб швидко знайти помилку. Читайте тут для отримання додаткової інформації.

function readFiles(filePaths) {
  return filePaths.map(
    (filePath) => {
      try {
        // ···
      } catch (error) {
        throw new Error(
          `While processing ${filePath}`,
          {cause: error}
        );
      }
    });
}
Enter fullscreen mode Exit fullscreen mode

5. Модулі очікування верхнього рівня

Тепер ми можемо використовувати await на верхніх рівнях модулів і більше не потрібно вводити асинхронні функції чи методи.

  • Динамічне завантаження модулів
const messages = await import(`./messages-${language}.mjs`);
Enter fullscreen mode Exit fullscreen mode
  • Використання резервного варіанту, якщо не вдається завантажити модуль
let lodash;

try {
  lodash = await import('https://primary.example.com/lodash');
} catch {
  lodash = await import('https://secondary.example.com/lodash');
}
Enter fullscreen mode Exit fullscreen mode
  • Використання будь-якого ресурсу, який завантажується найшвидше
const resource = await Promise.any([
  fetch('http://example.com/first.txt')
    .then(response => response.text()),
  fetch('http://example.com/second.txt')
    .then(response => response.text()),
]);
Enter fullscreen mode Exit fullscreen mode

6. Нові учасники класів

  • Публічні властивості можна створити за допомогою публічні поля екземпляра
class InstPublicClass {
  // Instance public field
  instancePublicField = 0; // (A)

  constructor(value) {
    // We don’t need to mention .property elsewhere!
    this.property = value; // (B)
  }
}

const inst = new InstPublicClass('constrArg');
Enter fullscreen mode Exit fullscreen mode
  • Статичні публічні поля
const computedFieldKey = Symbol('computedFieldKey');

class StaticPublicFieldClass {
  static identifierFieldKey = 1;
  static 'quoted field key' = 2;
  static [computedFieldKey] = 3;
}

console.log(StaticPublicFieldClass.identifierFieldKey) //output -> 1
console.log(StaticPublicFieldClass['quoted field key']) //output -> 2
console.log(StaticPublicFieldClass[computedFieldKey]) //output -> 3
Enter fullscreen mode Exit fullscreen mode
  • Приватні слоти є новими, і їх можна створити через приватні поля екземпляра
class InstPrivateClass {
  #privateField1 = 'private field 1'; // (A)
  #privateField2; // (B) required!

  constructor(value) {
    this.#privateField2 = value; // (C)
  }

  /**
   * Private fields are not accessible outside the class body.
   */
  checkPrivateValues() {
    console.log(this.#privateField1); // output -> 'private field 1'
    console.log(this.#privateField2); // output -> 'constructor argument'
  }
}

const inst = new InstPrivateClass('constructor argument');
inst.checkPrivateValues();


console.log("inst", Object.keys(inst).length === 0) // output -> inst, true
Enter fullscreen mode Exit fullscreen mode
  • Екземпляр і статичні приватні поля
class InstPrivateClass {
  #privateField1 = 'private field 1'; // (A)
  #privateField2; // (B) required!

  static #staticPrivateField = 'hello';

  constructor(value) {
    this.#privateField2 = value; // (C)
  }

  /**
   * Private fields are not accessible outside the class body.
   */
  checkPrivateValues() {
    console.log(this.#privateField1); // output -> 'private field 1'
    console.log(this.#privateField2); // output -> 'constructor argument'
  }

  static #twice() {
    return this.#staticPrivateField + " " + this.#staticPrivateField;
  }

  static getResultTwice() {
    return this.#twice()
  }
}

const inst = new InstPrivateClass('constructor argument');
inst.checkPrivateValues();


console.log("inst", Object.keys(inst).length === 0) // output -> "inst", true
console.log(InstPrivateClass.getResultTwice()); // output -> "hello hello"
Enter fullscreen mode Exit fullscreen mode
  • Приватні методи та засоби доступу
class MyClass {
  #privateMethod() {}

  static check() {
    const inst = new MyClass();

    console.log(#privateMethod in inst) // output-> true
    console.log(#privateMethod in MyClass.prototype) // output-> false
    console.log(#privateMethod in MyClass) // output-> false
  }
}

MyClass.check();
Enter fullscreen mode Exit fullscreen mode
  • Статичні блоки ініціалізації в класах. Для статичних даних у нас є статичні поля та статичні блоки, які виконуються під час створення класу
class Translator {
  static translations = {
    yes: 'ja',
    no: 'nein',
    maybe: 'vielleicht',
  };
  static englishWords = [];
  static germanWords = [];
  static { // (A)
    for (const [english, german] of Object.entries(this.translations)) {
      this.englishWords.push(english);
      this.germanWords.push(german);
    }
  }
}

console.log(Translator.englishWords, Translator.germanWords)
// Output -> ["yes", "no", "maybe"], ["ja", "nein", "vielleicht"]
Enter fullscreen mode Exit fullscreen mode
  • Перевірки приватних слотів. Ця функція допомагає нам перевірити, чи об’єкт має вказаний приватний слот
class C1 {
  #priv() {}

  static check(obj) {
    return #priv in obj;
  }
}

console.log(C1.check(new C1())) // output true
Enter fullscreen mode Exit fullscreen mode

Ці функції допоможуть нам покращити наші проекти та вдосконалити методи кодування 👩🏻‍💻.

Top comments (0)