Що таке ключове слово this в JavaScript

Якщо вас бентежить ключове слово this в JavaScript, знайте, що ви не самотні. Спочатку це бентежить усіх програмістів. Але це не означає, що вам не потрібно розібратися в цьому. Ключове слово this використовується так часто в підручниках і в коді JavaScript, що вам потрібно в ньому розібратися. Як тільки ви освоїте ключове слово this, ви зрозумієте, що це набагато простіше, ніж ви думали.

З цієї статті ви дізнаєтеся, що таке ключове слово this в JavaScript, що воно робить і як його використовувати.

 

 

Так що ж це таке ключове слово this?

this – це ключове слово, значення якого змінюється в залежності від того, як викликається функція. Є такі основні варіації, де воно може набувати різних значень:

  • this в глобальному контексті
  • this в конструкторі об’єкту
  • this в методі об’єкту
  • this в простій функції
  • this в слухачі подій

 

 

Давайте подивимося, як this змінюється в кожному з цих контекстів.

 

this в глобальному контексті

Коли this викликається поза будь-якою функцією, в глобальному контексті, в браузері за замовчуванням використовується об’єкт Window.

console.log (this); // об'єкт Window

 

Як правило, вам не потрібно використовувати this в глобальному контексті, оскільки його значення тут не важливе. Давайте перейдемо до наступного контексту.

 

 

this в конструкторі об’єкту

Коли ви створюєте новий екземпляр об’єкта з допомогою ключового слова new, ключове слово this відноситься до його примірника.

function Human(age) {
  this.age = age;
}
let ivan = new Human(22);
let stepan = new Human(24);
console.log(ivan); // this.age = 22
console.log(stepan); // this.age = 24

 

 

Вище в коді ivan є екземпляром Human. Тепер, коли б ви не посилалися на ivan, ви випадково не отримаєте stepan. Таким чином, встановлення this в якості прикладу має сенс.

Давайте подивимося на тісно пов’язаний контекст далі – this в методі об’єкту.

 

 

this в методі об’єкту

Методи – це позначення для функцій, які пов’язані з об’єктом. Оскільки ключове слово this відноситься до об’єкту, ви можете використовувати методи для отримання примірника об’єкта, наприклад:

function Human(name) {
 return {
   name,
   getName() {
    return this.name;
   }
 }
}
const ivan = new Human('Ivan');
const stepan = new Human('Stepan');
console.log(ivan.getName()); // Ivan

 

 

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

Давайте перейдемо до наступного контексту.

 

 

this в простій функції

Нижче приклад простої функції:

function hello() {
  // say hello!
}

 

Браузери this в простій функції завжди встановлюють в Window. Те ж саме вірно, навіть якщо ви викликаєте просту функцію в методі об’єкту.

На жаль, така поведінка є несподіваною для початківців. Вони очікують, що this залишиться тим же самим в методах об’єкта.

Одним з швидких рішень є створення змінної, яка зберігає посилання на this. Ця змінна часто називається self або that.

 

 

this в слухачах подій

Ключове слово this встановлюється для елемента, який викликав подію в слухачі подій:

let button = document.querySelector('button');
button.addEventListener('click', function() {
  console.log(this); // button
})

 

 

Зміна this з прив’язкою (bind)

bind – це метод, який присутній в кожній функції. Це дозволяє вам змінити контекст ключового слова this. Цей метод приймає будь-яку кількість аргументів і повертає пов’язану функцію.

function sayThis() {
  console.log(this);
}
const boundFunction = sayThis.bind(/* аргументи...*/);

 

 

Перший параметр, який ви передаєте в зв’язування, стає this в пов’язаній функції. Створивши пов’язану функцію, ви можете викликати її в будь-який час:

function sayThis() {
  console.log(this);
}
const boundFunction = sayThis.bind({greeting: 'hello'});
boundFunction();

 

 

Інші параметри, які ви передаєте в bind, будуть передані в якості аргументів вихідної функції

function sayParams(...args) {
  console.log(...args);
}
const boundFunction = sayParams.bind(null, 1, 2, 3, 4, 5);
boundFunction();

 

 

 

Заключна думка

Ключове слово this є одним з найважливіших ключових слів в JavaScript. Воно використовується в багатьох JavaScript-фреймворках, тому ви повинні знати, що воно робить.

З сьогоднішньої статті ви дізналися про різні контексти, в яких this приймає різні значення. Ви також дізналися, як змінити контекст this за допомогою таких функцій, як зв’язування (bind).

Це той мінімум, який вам потрібно знати про this. Просто засвойте концепції, викладені в цій статті, і ви більше ніколи не заплутаєтеся.

Чи допомогла вам ця стаття? Якщо так, сподіваємося, що ви поділитеся нею.

Дякуємо за увагу!

 

Recent Posts

Як купувати техніку з гарантією та вигодою в МТА

Коли мені хочеться освіжити свій гаджет, прикупити ігрову консоль чи, наприклад, розумний пилосос для дому,…

13 години ago

Що таке піддомен (субдомен) і коли його використовувати | SEO та приклади

Уявіть, що ваш основний сайт — це великий будинок, що стоїть на вашій земельній ділянці…

2 дні ago

Френк МакКінні Кін Хаббард

Є два способи командувати жінкою, але ніхто їх не знає Френк МакКінні Кін Хаббард  

4 дні ago

Роберт Шеклі

Найгірше, що в інформаційній війні завжди програє той, хто говорить правду, адже він обмежений правдою,…

5 днів ago

Річард Бах

Якщо тобі колись захочеться знайти таку людину, яка зможе здолати будь-яку, навіть найважчу біду і…

6 днів ago

Що таке CDN і чому він потрібен вашому сайту | огляд в 2025

Уявіть, що ви відкрили піцерію у Києві. Ваша піца настільки смачна, що її хочуть замовити…

1 тиждень ago