Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

Документы

Медиа

Назад
Вопрос про JavaScript: function, declaration, arrow

Как объявляются функции в JavaScript и чем отличаются function declaration и arrow function?

Проверяет понимание способов объявления функций и различий в поведении this, hoisting и синтаксисе.

Короткий ответ

Function declaration объявляется через ключевое слово function и поднимается (hoisting). Arrow function записывается через стрелочный синтаксис и не имеет собственного this. Также arrow function нельзя использовать как конструктор и у нее нет arguments.

Длинный ответ

В JavaScript существует несколько способов объявления функций, но чаще всего сравнивают function declaration и arrow function.

Function declaration

function sum(a, b) {
  return a + b;
}

Особенности:

  • поднимается (hoisting)

  • имеет собственный this

  • можно использовать как конструктор

Arrow function

const sum = (a, b) => a + b;

Особенности:

  • не имеет собственного this

  • не поднимается как declaration

  • нельзя использовать с new

Главное отличие this

const obj = {
  value: 10,
  method() {
    setTimeout(() => {
      console.log(this.value);
    });
  }
};

Arrow function берет this из внешнего контекста.

Когда что использовать

  • Arrow function — колбэки, обработчики, функциональные компоненты

  • Function declaration — методы, конструкторы, API

Вывод

Arrow function удобны для коротких функций и колбэков, а function declaration — для объявлений, требующих hoisting или собственного контекста.

Уровень

  • Рейтинг:

    5

  • Сложность:

    5

Навыки

  • JavaScript

    JavaScript

Ключевые слова

#function

#declaration

#arrow

Подпишись на React Developer в телеграм