作用域:指一个变量的作用范围。
在JS中,一共有两种作用域:
- 全局作用域
- 函数作用域
全局作用域:
直接编写在script标签中的JS代码,都在全局作用域。
全局作用域在页面打开时创建,在页面关闭时销毁。
在全局作用域中,有一个全局对象window,它代表的是一个浏览器的窗口,由浏览器创建,我们可以直接使用。
在全局作用域中,创建的变量都会作为window对象的属性保存。
var a =14;
console.log(a); // 14
// 其实a保存到了window对象里,所以可以window.a
console.log(window.a); // 14
console.log(window.b); // 报错
变量的声明提前
使用var关键字声明的变量,会在所有代码执行之前被声明。
console.log(b); // 结果为undefined
var b = 34;
// 上面的写法相当于:
var b;
console.log(b);
b = 34;
如果声明变量时不使用关键字var,则变量不会被声明提前。
console.log(b); // 报错
b = 10;
函数的声明提前
使用函数声明形式创建的函数 function 函数名(){},会在所有代码执行之前就被创建,所以可以在函数声明前调用函数。
fun(); // 输出hello
function fun(){
console.log("hello");
}
使用函数表达式创建的函数 var 函数名 = function(){},不会被声明提前,所以不能在声明前调用。
fun2(); // 会报错
var fun2 = function(){
console.log("chinese");
}