Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Войти

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

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

© 2026 YeaHub

Документы

Медиа

Назад
Вопрос про JavaScript: замыкание, функция, iife

Какие бывают проблемы с использованием замыканий, особенно в циклах? Как их можно избежать?

Этот вопрос проверяет понимание работы замыканий в JavaScript и как они могут привести к проблемам, особенно при использовании в циклах, где переменные могут вести себя не так, как ожидается.

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

Замыкания — это функция, которая запоминает свое окружение. Проблема возникает, когда в циклах замыкания "запоминают" одно и то же значение переменной, которая изменяется на каждой итерации. Это приводит к тому, что все замыкания используют одно и то же последнее значение. Чтобы избежать этой проблемы, можно использовать let вместо var или создавать новую область видимости с помощью IIFE.

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

Замыкание — это функция, которая "запоминает" переменные из своего лексического окружения, даже если эта функция выполняется вне своего исходного контекста. Проблема с замыканиями в циклах возникает, когда замыкание "схватывает" переменную, которая изменяется на каждой итерации, но при выполнении всех замыканий эта переменная уже имеет конечное значение.

Пример с проблемой:

for (var i = 1; i <= 3; i++) {
  	setTimeout(() => console.log(i), 1000); 
} 
// Выведет три раза 4, вместо 1, 2, 3

Это происходит потому, что замыкание в каждом вызове setTimeout использует одно и то же значение i, которое уже изменилось к моменту выполнения.

Решение проблемы — использование let, который создает новую область видимости для каждой итерации цикла:

for (let i = 1; i <= 3; i++) {
  	setTimeout(() => console.log(i), 1000); // 1, 2, 3 
}

Другой способ — использовать немедленно вызываемую функцию (IIFE), которая создаст новую область видимости:

for (var i = 1; i <= 3; i++) {
  	(function(i) {
      		setTimeout(() => console.log(i), 1000);  
  	})(i); 
}

Эти методы предотвращают проблему, обеспечивая сохранение уникального значения для каждой итерации, что важно для правильной работы замыканий в циклах.

Уровень

  • Рейтинг:

    3

  • Сложность:

    6

Навыки

  • JavaScript

    JavaScript

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

#замыкание

#функция

#iife

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