JavaScript基础第05天笔记
作用域
通常来说,一段程序代码中所用到的名字并不总是有效和可用的,而限定这个名字的可用性的代码范围就是这个名字的作用域。
简单理解:作用域就是代码起作用的范围
作用域的使用提高了程序逻辑的局部性,增强了程序的可靠性,减少了名字冲突。
JavaScript(ECMAScript6前)中的作用域有两种:
- 全局作用域
- 局部作用域(函数作用域)
全局作用域
作用于所有代码执行的环境(整个 script 标签内部)或者一个独立的 js 文件。
<script>
var num = 30; //全局作用域
console.log(num);
</script>
局部作用域
作用于函数内的代码环境,就是局部作用域。
只在函数内部起效果和作用。
因为跟函数有关系,所以也称为函数作用域。
<script>
function fn() {
//局部作用域
var num = 20; // 局部作用域
console.log(num);
}
fn();
</script>
例子
<script>
//全局作用域: 整个script标签 或者是一个单独的js文件
var num = 10;
var num = 30;
console.log(num);
//局部作用域(函数作用域): 在函数内部就是局部作用域 这个代码的名字只在函数内部起效果和作用
function fn() {
// 局部作用域
var num = 20;
console.log(num);
}
fn();
</script>
JS没有块级作用域
-
块作用域由 { } 包括。
在其他编程语言中(如 java、c#等),在 if 语句、循环语句中创建的变量,仅仅只能在本 if 语句、本循环语句中使用
-
java有块级作用域:
if(true){ int num = 123; system.out.print(num); // 123 } system.out.print(num); // 报错
以上java代码会报错,是因为代码中 { } 即一块作用域,其中声明的变量 num,在 “{ }” 之外不能使用。
而与之类似的JavaScript代码,则不会报错:
-
在ES6之前,Js中没有块级作用域(在ES6之前,ES6就是ECMAScript6)
if(true){
var num = 123;
console.log