变量的作用域
- 全局变量拥有全局的作用域,函数内声明的变量只在函数体内有定义。
- 在函数体内局部变量的优先级高于全局变量
var scope = "global"
function checkscope(){
var scope = "local"
return scope
}
checkscope()//"local"
- 局部变量必须用var关键字来声明,否则当声明一个和全局变量同名的变量时,会修改全局变量的值
函数作用域和声明提前
- 变量的声明在它们的函数体和嵌套的任意函数体内都是有定义的
变量在声明之前即可使用,js的特性,成为“声明提前“,因为在预编译时,引擎已经将声明提前了,var variable,但是并没有赋值
var scope = "global" function checkscope(){ console.log(scope)//undefined,并不会输出global,因为编译器会提前声明一个var scope,所以是undefined var scope = "local" console.log(scope)//local }
- 但是通常在顶部声明变量是一个良好的编程习惯,有助于他人理解变量意图
作用域链
每一段js代码(全局代码或者函数)都有一个与之关联的作用域链(scope chain)。作用域链是一个对象列表或链表,这组对象定义了这段代码”作用域中”的变量。作用域链对于闭包的理解至关重要。
构造函数
new Object()
new Point(2,3)
如果一个构造函数不需要任何参数,则括号可以省略
new Object
new Date