web前端自学之路

web前端 -- Day13 js基础

2019-02-28  本文已影响0人  韩发发吖

作用域

作用域:适用范围。写代码要注意变量在哪声明和使用的问题。

全局变量和全局变量
1、全局变量:声明的变量是使用var声明的,那么这个变量就是全局变量,全局变量可以在页面的任何位置使用
2、全局变量:在函数内部定义的变量,是局部变量,外面不能使用

注:除了函数以外,其他的任何位置定义的变量都是全局变量,全局变量如果页面不关闭,那么就不会释放,就会占用内存

全局作用域和局部作用域
1、全局作用域:全局变量的使用范围
2、局部作用域:局部变量的使用范围

块级作用域
块级作用域:一堆大括号就可看作是一块,在这块区域中定义的变量中只能在这块区域中使用,但是在js中在这个块级作用域中定义的变量,外面也能使用。
说明:js没有块级作用域,只有函数除外

隐式全局变量
隐式全局变量:声明变量没有var ,就叫做隐式全局变量

num = 100;
console.log(num);
function f1 () {
    num = 10000; // 隐式全局变量大括号外边也可以访问
}
f1();
console.log (num);

总结:
1、全局变量是不能被删除的,隐式全局变量是可以被删除的
2、定义变量使用var不能被删除的,没有var是可以被删除的

预解析

预解析:提前解析代码。在解析代码之前,把变量的声明提前(提前到当前所在的作用域的最上面)

// 函数调用的时候,会把函数的声明提升到作用域上面
f2(); //调用
var  num = 20;// 这个变量的声明会提升到变量使用之前
function f2() { 
    console.log(num); // 打印undefined
    var  num = 10;
}

// 预解析中,变量的提升,只会在当前作用域中提升,提前到当前作用域中的最前面
// 函数中的变量只会提升到函数作用域的最前面,不会出去
// 预解析会分段(多对的script标签中的函数重名,预解析的时候不会冲突)
function f3() { 
    console.log(num); // 打印undefined
    var  num = 10;
}
f3(); //调用
console.log(num);
上一篇 下一篇

猜你喜欢

热点阅读