变量与作用域

Posted 2350305682

tags:

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

一、var box="blue";
function setColor(){
return 123;
}
alert(box);==alert(window.box); ---blue //全局变量属于window的属性
alert(setColor());==alert(window.setColor()); ---123 //全局函数属于window的方法

二、var box="blue";
function setColor(){
var box="red";
}
setColor();
alert(box);---blue //因为setColor函数是在window全局作用局下的方法,所以,alert出来的也是全局下的变量。

var box="blue";
function setColor(){
box="red"; //去掉了var,这个变量就是全局变量了
}
setColor();
alert(box);---red

三、var box="blue";
function setColor(box){
alert(box);----red //传参也是局部变量
}
setColor("red");
alert(box);---blue

四、作用域链,函数体内还包含着函数,只有这个函数才可以访问内一层的函数。

function setBox() {

function setColor() {
return 123;
}
}
alert(setColor());会报错,因为setColor()方法的作用域在setBox(),而不是window内。那怎么调用setColor呢:
function setBox() {

function setColor() {
return 123;
}
return setColor();
}
alert( setBox());这样就可以了

但是if语句的花括号等代码块没有作用域的功能,也就是说它们可以通过window全局去访问的。

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

作用域和作用域链

作用域和作用域链

var与let区别-详解块级作用域与局部作用域

var与let区别-详解块级作用域与局部作用域

javaScript教程50: 变量查找规则与词法作用域

九 作用域与闭包