Учебник по JS

ГЛАВНАЯ JS Введение JS Куда Вывод JS Заявления JS JS-синтаксис JS-комментарии JS-переменные JS Пусть Константа JS JS-операторы JS-арифметика Назначение JS JS-типы данных JS-функции JS-объекты JS-события JS-строки Строковые методы JS Поиск строки JS Шаблоны строк JS JS-номера Методы номеров JS JS-массивы Методы массива JS Сортировка массива JS Итерация массива JS Константа массива JS JS-даты Форматы даты JS Методы получения даты JS Методы установки даты JS JS-математика JS Случайный JS Булевы значения Сравнение JS JS-условия JS-переключатель JS цикл для Цикл JS для входа Цикл JS для Цикл JS во время Перерыв JS JS-итерации JS-наборы JS-карты JS Typeof Преобразование типов JS JS побитовый JS регулярное выражение JS-ошибки Область JS JS-подъем Строгий режим JS JS это ключевое слово Функция стрелки JS JS-классы JS JSON JS-отладка Руководство по стилю JS Лучшие практики JS JS-ошибки JS-производительность Зарезервированные слова JS

JS-версии

JS-версии JS 2009 (ES5) JS 2015 (ES6) JS 2016 JS 2017 JS 2018 JS IE/пограничный История JS

JS-объекты

Определения объектов Свойства объекта Методы объекта Отображение объекта Средства доступа к объектам Конструкторы объектов Прототипы объектов Итерации объектов Наборы объектов Карты объектов Ссылка на объект

JS-функции

Определения функций Параметры функции Вызов функции Вызов функции Функция Применить Закрытие функций

JS-классы

Введение в класс Наследование классов Статический класс

JS асинхронный

Обратные вызовы JS JS асинхронный JS-обещания JS асинхронный/ожидание

JS HTML DOM

Дом Введение DOM-методы Документ DOM DOM-элементы DOM HTML DOM-формы ДОМ CSS DOM-анимации События ДОМ Слушатель событий DOM DOM-навигация DOM-узлы Коллекции DOM Списки узлов DOM

Спецификация браузера JS

JS-окно JS-экран Местоположение JS История JS JS-навигатор Всплывающее оповещение JS JS Тайминг JS-куки

JS-веб-API

Введение в веб-API API веб-форм API истории веб-поиска API веб-хранилища API веб-работника API веб-выборки API веб-геолокации

JS АЯКС

Введение в АЯКС AJAX XMLHttp АЯКС-запрос AJAX-ответ XML-файл AJAX АЯКС PHP АЯКС АСП База данных AJAX AJAX-приложения Примеры AJAX

JS JSON

Введение в JSON Синтаксис JSON JSON против XML Типы данных JSON Анализ JSON Строковая JSON JSON-объекты JSON-массивы JSON-сервер JSON PHP JSON HTML JSON JSONP

JS против JQuery

Селекторы jQuery JQuery HTML jQuery CSS JQuery DOM

JS-графика

JS-графика JS Холст JS сюжет JS Chart.js JS Google Диаграмма JS D3.js

JS-примеры

JS-примеры JS HTML DOM JS HTML-ввод HTML-объекты JS HTML-события JS JS-браузер JS-редактор JS-упражнения JS-викторина JS-сертификат

JS-ссылки

Объекты JavaScript HTML DOM-объекты


Подъем JavaScript


Подъем — это поведение JavaScript по умолчанию для перемещения объявлений наверх.


Объявления JavaScript поднимаются

В JavaScript переменная может быть объявлена ​​после ее использования.

Другими словами; переменная может использоваться до того, как она была объявлена.

Пример 1 дает тот же результат, что и пример 2 :

Пример 1

x = 5; // Assign 5 to x

elem = document.getElementById("demo"); // Find an element
elem.innerHTML = x;                     // Display x in the element

var x; // Declare x

Пример 2

var x; // Declare x
x = 5; // Assign 5 to x

elem = document.getElementById("demo"); // Find an element
elem.innerHTML = x;                     // Display x in the element

Чтобы понять это, вы должны понять термин «подъем».

Подъем — это поведение JavaScript по умолчанию, когда все объявления перемещаются в верхнюю часть текущей области (в верхнюю часть текущего скрипта или текущей функции).


Ключевые слова let и const

Переменные, определенные с помощью letи const, поднимаются наверх блока, но не инициализируются .

Значение: Блок кода знает о переменной, но ее нельзя использовать, пока она не будет объявлена.

Использование letпеременной до ее объявления приведет к созданию файла ReferenceError.

Переменная находится во «временной мертвой зоне» с начала блока до ее объявления:

Пример

Это приведет к ReferenceError:
carName = "Volvo";
let carName;

Использование constпеременной до ее объявления является синтаксической ошибкой, поэтому код просто не запустится.

Пример

Этот код не будет работать.

carName = "Volvo";
const carName;

Подробнее о let и const читайте в JS Let/Const .



Инициализации JavaScript не поднимаются

JavaScript поднимает только объявления, а не инициализации.

Пример 1 не дает такого же результата, как пример 2 :

Пример 1

var x = 5; // Initialize x
var y = 7; // Initialize y

elem = document.getElementById("demo"); // Find an element
elem.innerHTML = x + " " + y;           // Display x and y

Пример 2

var x = 5; // Initialize x

elem = document.getElementById("demo"); // Find an element
elem.innerHTML = x + " " + y;           // Display x and y

var y = 7; // Initialize y

Имеет ли смысл, что y не определено в последнем примере?

Это связано с тем, что наверх поднимается только объявление (var y), а не инициализация (=7).

Из-за подъема y был объявлен до его использования, но поскольку инициализации не поднимаются, значение y не определено.

Пример 2 аналогичен написанию:

Пример

var x = 5; // Initialize x
var y;     // Declare y

elem = document.getElementById("demo"); // Find an element
elem.innerHTML = x + " " + y;           // Display x and y

y = 7;    // Assign 7 to y

Объявите свои переменные вверху!

Поднятие (для многих разработчиков) неизвестное или упускаемое из виду поведение JavaScript.

Если разработчик не понимает подъем, программы могут содержать баги (ошибки).

Чтобы избежать ошибок, всегда объявляйте все переменные в начале каждой области видимости.

Так как JavaScript интерпретирует код именно так, это всегда хорошее правило.

JavaScript в строгом режиме не позволяет использовать переменные, если они не объявлены.
Изучите «use strict» в следующей главе.