-
Notifications
You must be signed in to change notification settings - Fork 0
function scope sample 4
var __num = 1
function __showNum () {
console.info ( "Вошли в контекст исполнения функции __showNum" )
console.info ( `__num === ${__num}` )
return
function __num () {}
}
__showNum ()
console.info ( "Вышли из контекста исполнения функции __showNum" )
console.info ( `Теперь __num === ${__num}` )
В этом примере показано, как работает механизм hoisting
Переменная __num
объявляется в глобальной области видимости с присвоением ей значения 1
Внутри тела функции __showNum
после оператора return объявляется функция __num
На первый взгляд, при последовательном выполнении кода это объявление не должно сработать, поскольку оператор return
стоит выше
Однако все объявления собираются в объект активации до того, как код начинает выполняться
Поэтому на момент, когда начнется выполнение кода функции __showNum
, функция __num
будет уже объявлена и будет благополучно находиться в Lexical Environment
функции __showNum
Благодаря этому объявления переменных и функций "поднимаются" в области видимости "родителя" ( в нашем случае "родителем" является функция __showNum
)
Убедиться в этом позволяет вывод в консоль переменной __num
После завершения выполнения кода функции __showNum
ее контекст будет "демонтирован", и опять активным станет глобальный контекст, в котором переменная __num
имеет значение 1
Курсы были созданы для студентов A-Level Ukraine.
Использование данных материалов или любой их части коммерческими школами ( курсами ) является нарушением авторских прав.
1 | 2 | 3 | 4 | 5 |
6 | 7 | 8 | 9 | 10 |
11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 |
⏬ |
---|
- Блок-схема алгоритма
- Developer Tools
- Chrome DevTools
- Переменные
- Оператор typeof
- Структуры данных
- Операторы присваивания
- Логические выражения
- Условные операторы
- Инкремент
- Свойство length
- Оператор цикла for
- UTF-8
Homework
- Нативные и host-объекты
- Литерал объекта
- Унаследованные свойства
- Конструктор
- Модель наследования
- Публичные и приватные свойства
- Оператор in
1
Homework
- Итерирующие методы массивов
- Тестирование производительности
- SHA
Homework
- strict mode
- Вычисляемые имена свойств
- Краткий синтаксис методов
- Краткий литерал объекта
- Классы
Homework
- npm
- webpack
Упражнение 1
- ES6 модули
Упражнение 2
- --mode | --watch
Упражнение 3
Упражнение 4
Упражнение 5
Упражнение 6
Упражнение 7
Упражнение 8
Homework
⏫ |
---|