3.10. Область видимости переменной
Область видимости ( scope
) переменной - это та часть программы, для которой эта переменная определена. Глобальная переменная имеет глобальную область видимости - она определена для всей JavaScript-программы. В то же время переменные, объявленные внутри функции, определены только в ее теле. Они называются локальными и имеют локальную область видимости. Параметры функций также считаются локальными переменными, определенными только в теле этой функции.
Внутри тела функции локальная переменная имеет преимущество перед глобальной переменной с тем же именем. Если объявить локальную переменную или параметр функции с тем же именем, что у глобальной переменной, то фактически глобальная переменная будет скрыта:
var scope = "global"; // Объявление глобальной переменной
function checkscope() {
var scope = "local"; // Объявление локальной переменной с тем же именем
return scope; // Вернет локальное значение, а не глобальное
}
checkscope() // => "local"
Объявляя переменные с глобальной областью видимости, инструкцию var
можно опустить, но при объявлении локальных переменных всегда следует использовать инструкцию var
. Посмотрите, что получается, если этого не сделать:
scope = "global";// Объявление глобальной переменной, даже без var.
function checkscope2() {
scope = "local"; // Ой! Мы изменили глобальную переменную.
myscope = "local"; // Неявно объявляется новая глоб. переменная.
return [scope, myscope];// Вернуть два значения.
checkscope2() // => ["local", "local"]: имеется побочный эффект!
scope // => "local": глобальная переменная изменилась.
myscope // => "local": нарушен порядок в глобальном пространстве имен.
Определения функций могут быть вложенными. Каждая функция имеет собственную локальную область видимости, поэтому может быть несколько вложенных уровней локальных областей видимости. Например:
var scope = "global scope"; // Глобальная переменная
function checkscopeO {
var scope = "local scope”; // Локальная переменная
function nestedO {
var scope = "nested scope"; // Вложенная область видимости локальных переменных
return scope; // Вернет значение этой переменной scope
}
return nested();
}
3.10.1. Область видимости функции и подъем
В некоторых С-подобных языках программирования каждый блок программного кода внутри фигурных скобок имеет свою собственную область видимости, а переменные, объявленные внутри этих блоков, невидимы за их пределами. Эта особенность называется областью видимости блока, но она не поддерживается в языке JavaScript. Вместо этого в JavaScript используется такое понятие, как область видимости функции: переменные, объявленные внутри функции, доступны внутри функции, где они объявлены, а также внутри всех функций, вложенных в эту функцию.
В следующем фрагменте переменные i, j и к объявляются в разных местах, но все они имеют одну и ту же область видимости - все три переменные доступны из любого места в теле функции:
function test(o) {
var і = 0; // і определена в теле всей функции
if (typeof о == "object") {
var j = 0; // j определена везде, не только в блоке
for(var k=0; k < 10; k++) { // к определена везде, не только в цикле
console.log(k); // выведет числа от 0 до 9
}
console.log(k); // к по-прежнему определена: выведет 10
}
console.log(j); // j определена, но может быть неинициализирована
}
Область видимости функции в языке JavaScript подразумевает, что все переменные, объявленные внутри функции, видимы везде в теле функции. Самое интересное, что переменные оказываются видимыми еще до того, как будут объявлены. Эта особенность JavaScript неофициально называется подъемом: программный код JavaScript ведет себя так, как если бы все объявления переменных внутри функции (без присваивания инициализирующих значений) «поднимались» в начало функции. Рассмотрим следующий фрагмент:
var scope = "global";
function f() {
console.log(scope); // Выведет "undefined", а не "global"
var scope = "local"; // Инициализируется здесь, а определена везде
Читать дальше
Конец ознакомительного отрывка
Купить книгу