html5中文学习网

您的位置: 首页 > 网站及特效实例 > javascript特效 » 正文

JavaScript作用域示例详解_javascript技巧_

[ ] 已经帮助:人解决问题

作用域是JavaScript最重要的概念之一,想要学好JavaScript就需要理解JavaScript作用域和作用域链的工作原理。今天这篇文章对JavaScript作用域示例详解的介绍,希望能帮助大家更好的学习JavaScript。DtmHTML5中文学习网 - HTML5先行者学习网

任何程序设计语言都有作用域的概念,简单的说,作用域就是变量与函数的可访问范围,即作用域控制着变量与函数的可见性和生命周期。在JavaScript中,变量的作用域有全局作用域和局部作用域两种。DtmHTML5中文学习网 - HTML5先行者学习网

一、JavaScript中无块级作用域DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

在Java或C#中存在块级作用域,即:大括号也是一个作用域。DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

public static void main (){if(1==1){String name = "seven";}System.out.println(name);}// 报错 public static void Main(){if(1==1){string name = "seven";}Console.WriteLine(name);}// 报错 

在JavaScript语言中无块级作用域DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

function Main(){if(1==1){var name = 'seven';}console.log(name);}// 输出: seven 

二、JavaScript采用函数作用域DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

在JavaScript中每个函数作为一个作用域,在外部无法访问内部作用域中的变量。DtmHTML5中文学习网 - HTML5先行者学习网

function Main(){var innerValue = 'seven';}Main();console.log(innerValue);// 报错:Uncaught ReferenceError: innerValue is not defined 

三、JavaScript的作用域链DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

由于JavaScript中的每个函数作为一个作用域,如果出现函数嵌套函数,则就会出现作用域链。DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

xo = 'alex';function Func(){var xo = "seven";function inner(){var xo = 'alvin'; console.log(xo);}inner();}Func(); 

如上述代码则出现三个作用域组成的作用域链,如果出现作用域链后,那么寻找变量时候就会出现顺序,对于上述实例:DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

当执行console.log(xo)时,其寻找顺序为根据作用域链从内到外的优先级寻找,如果内层没有就逐步向上找,直到没找到抛出异常。DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

四、JavaScript的作用域链执行前已创建DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

JavaScript的作用域在被执行之前已经创建,日后再去执行时只需要按照作用域链去寻找即可。DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

示例一:DtmHTML5中文学习网 - HTML5先行者学习网

xo = 'alex';function Func(){var xo = "seven";function inner(){console.log(xo);}return inner;}var ret = Func();ret();// 输出结果: seven 

上述代码,在函数被调用之前作用域链已经存在:DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

•全局作用域 -> Func函数作用域 -> inner函数作用域DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

当执行【ret();】时,由于其代指的是inner函数,此函数的作用域链在执行之前已经被定义为:全局作用域 -> Func函数作用域 -> inner函数作用域,所以,在执行【ret();】时,会根据已经存在的作用域链去寻找变量。DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

示例二:DtmHTML5中文学习网 - HTML5先行者学习网

xo = 'alex';function Func(){var xo = "eirc";function inner(){console.log(xo);}xo = 'seven';return inner;}var ret = Func();ret();// 输出结果: seven

上述代码和示例一的目的相同,也是强调在函数被调用之前作用域链已经存在:DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

•全局作用域 -> Func函数作用域 -> inner函数作用域DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

不同的时,在执行【var ret = Func();】时,Func作用域中的xo变量的值已经由 “eric” 被重置为 “seven”,所以之后再执行【ret();】时,就只能找到“seven”。DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

示例三:DtmHTML5中文学习网 - HTML5先行者学习网

xo = 'alex';<br>function Bar(){console.log(xo);}function Func(){var xo = "seven";return Bar;}var ret = Func();ret();// 输出结果: alex 

上述代码,在函数被执行之前已经创建了两条作用域链:DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

•全局作用域 -> Bar函数作用域DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

•全局作用域 -> Func函数作用域DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

当执行【ret();】时,ret代指的Bar函数,而Bar函数的作用域链已经存在:全局作用域 -> Bar函数作用域,所以,执行时会根据已经存在的作用域链去寻找。DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

五、声明提前DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

在JavaScript中如果不创建变量,直接去使用,则报错:DtmHTML5中文学习网 - HTML5先行者学习网

console.log(xxoo);// 报错:Uncaught ReferenceError: xxoo is not defined 

JavaScript中如果创建值而不赋值,则该值为 undefined,如:DtmHTML5中文学习网 - HTML5先行者学习网

var xxoo;console.log(xxoo);// 输出:undefined 

在函数内如果这么写:DtmHTML5中文学习网 - HTML5先行者学习网

function Foo(){console.log(xo);var xo = 'seven';}Foo();// 输出:undefined

上述代码,不报错而是输出 undefined,其原因是:JavaScript的函数在被执行之前,会将其中的变量全部声明,而不赋值。所以,相当于上述实例中,函数在“预编译”时,已经执行了var xo;所以上述代码中输出的是undefined。DtmHTML5中文学习网 - HTML5先行者学习网
DtmHTML5中文学习网 - HTML5先行者学习网

以上所述是小编给大家介绍的JavaScript作用域示例详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!DtmHTML5中文学习网 - HTML5先行者学习网

(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助