在JS中变量是使用var关键字声明的,由var声明的变量是永久的。
可以使用var多次声明同一个变量,当给一个没有声明的变量赋值时,JS会自动用那个变量创建一个全局变量。
如果想在函数内部创建一个局部变量,那就必须用var在函数内部声明。
由var声明的变量是永久的,即用delete运算符来删除这些变量将会出现错误。
要注意,隐式声明的变量只能被创建为全局变量,即使该变量只在一个函数体内使用。
无论是全局变量还是局部变量,最好都使用var语句声明。
在函数体内部,局部变量的优先级比同名的全局变量高。如果给一个局部变量或函数的参数声明的名字与某个全局变量的名字相同,那么就有效地隐藏了这个全局变量。
在JS1.2中,函数定义是可以嵌套的。由于每个函数都有它自己的局部作用域,所以有可能出现几个局部作用域的嵌套层,如以下代码所示:
JS和C以及java不同,JS没有块级作用域。函数中声明的所有变量,无论是在哪里声明的,在整个函数中它们都是有定义的。
请看以下的代码:
可以使用var多次声明同一个变量,当给一个没有声明的变量赋值时,JS会自动用那个变量创建一个全局变量。
如果想在函数内部创建一个局部变量,那就必须用var在函数内部声明。
由var声明的变量是永久的,即用delete运算符来删除这些变量将会出现错误。
要注意,隐式声明的变量只能被创建为全局变量,即使该变量只在一个函数体内使用。
无论是全局变量还是局部变量,最好都使用var语句声明。
在函数体内部,局部变量的优先级比同名的全局变量高。如果给一个局部变量或函数的参数声明的名字与某个全局变量的名字相同,那么就有效地隐藏了这个全局变量。
在JS1.2中,函数定义是可以嵌套的。由于每个函数都有它自己的局部作用域,所以有可能出现几个局部作用域的嵌套层,如以下代码所示:
var scope="global scope "; //一个全局变量
function chechscope(){
var scope="local scope"; //一个局部变量
function nested(){
var scope="nested scope"; //局部变量的嵌套作用域
document.write(scope); //输出“nested scope”
}
nested();
}
checkscope();
JS和C以及java不同,JS没有块级作用域。函数中声明的所有变量,无论是在哪里声明的,在整个函数中它们都是有定义的。
请看以下的代码:
var scope="global";
function f(){
alert(scope); //显示“undefined”,而不是“global”
var scope="local"; //变量在此处被初始化,但到处都有定义
alert(scope); //显示“local”
}
f();