JavaScript基础:作用域

Posted 陈希瑞

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript基础:作用域相关的知识,希望对你有一定的参考价值。

javascript基础:作用域

一、概念

作用域指一个变量的作用的范围,在JS中有两种作用域:全局作用域和局部作用域。

二、全局作用域

  1. 直接编写在script标签中的JavaScript代码,都在全局作用域
var a = 10;
console.log(a);
  1. 全局作用域在页面打开时创建,在页面关闭时销毁
  2. 在全局作用域中一个全局对象window【它代表的是一个浏览器窗口,它由浏览器创建】,我们可以直接使用
  3. 在全局作用域中:
  • 创建的变量都会作为window对象的属性保存
var a = 10;
console.log(a);
console.log(window.a);
  • 创建的函数都会作为window对象的方法保存
function fun()
	console.log("我是fun函数!!!")

fun();
window.fun();
//以此类推
alert("Hello world!");
window.alert("Hello world!");
  1. 变量的声明提前
  • 使用var关键字声明的变量,会在所有的代码执行之前被声明。
console.log("a = " + a);
var a = 10; //a = undefined 
  • 如果声明变量时不使用var关键字,则不会提前声明。
console.log("b = " + b);
b = 10; //UncaughtReferenceError: b is not defined

三、函数(局部)作用域

  1. 调用函数是创建函数作用域,函数执行完毕以后,函数作用域销毁

  2. 每调用一次函数就会创建一个新的函数作用域,他们之间是相互独立的

fun();
fun();
fun();
  1. 在函数作用域中可以访问全局作用域的变量
var a = 10;

function fun() 
	console.log("a = " + a);

fun();
  1. 在全局作用域中无法访问函数作用域的变量
function fun() 
	var b = 123;
	console.log(b);

fun();
//会报错,b变量仅在函数中有效
console.log(b);
  1. 当在函数作用域中操作一个变量时,它会先在自身作用域中寻找。如果有就直接使用;如果没有则向上一级作用域中寻找。
var a = 10;
function fun() 
	var a = "我是函数变量中的a";
	console.log("a = " + a);	//a = 我是函数变量中的a

fun();
console.log("a = " + a);	//a = 10
  1. 在函数作用域中也有声明提前的特性:使用var关键字声明的变量,会在所有的代码执行之前被声明。
function fun3()
	console.log(a);//undefined
	var a = 35;

fun3();
  1. 在函数中,不使用var声明的变量都会成为全局变量
var c = 36function fun5() 
	//console.log("c = " + c);
	c = 10;

fun5();
// 在全局输出c
console.log("c = " + c); //c = 10
function fun()
	// d没有使用var关键字,则会设置为全局变量
	d = 100;

fun();
console.log("d = " + d); //d = 100

以上是关于JavaScript基础:作用域的主要内容,如果未能解决你的问题,请参考以下文章

JavaScript作用域闭包简述

JavaScript基础 作用域 this 原型

JSP中四种对象作用域都有哪些区别?

浅谈JS的作用域链(二)

js改变作用域链

回归基础: JavaScript 变量提升