五句话搞定JavaScript作用域【转】
JavaScript的作用域一直以来是前端开发中比较难以理解的知识点,对于JavaScript的作用域主要记住几句话,走遍天下都不怕...
一、“JavaScript中无块级作用域”
在Java或C#中存在块级作用域,即:大括号也是一个作用域。
public static void main ()
{
if(1==1){
String name = "seven";
}
System.out.println(name);
}
// 报错 Java
java
public static void Main()
{
if(==){
string name = "seven";
}
Console.WriteLine(name);
}
// 报错 C#
C#
在JavaScript语言中无块级作用域
| 1 2 3 4 5 6 7 | functionMain(){    if(1==1){        varname = 'seven';    }    console.log(name);}// 输出: seven | 
补充:标题之所以添加双引号是因为JavaScript6中新引入了 let 关键字,用于指定变量属于块级作用域。
二、JavaScript采用函数作用域
在JavaScript中每个函数作为一个作用域,在外部无法访问内部作用域中的变量。
| 1 2 3 4 5 6 7 8 9 | functionMain(){    varinnerValue = 'seven';}Main();console.log(innerValue);// 报错:Uncaught ReferenceError: innerValue is not defined | 
三、JavaScript的作用域链
由于JavaScript中的每个函数作为一个作用域,如果出现函数嵌套函数,则就会出现作用域链。
| 1 2 3 4 5 6 7 8 9 10 11 | xo = 'alex'; functionFunc(){    varxo = "seven";    functioninner(){        varxo = 'alvin';        console.log(xo);    }    inner();}Func(); | 
如上述代码则出现三个作用域组成的作用域链,如果出现作用域链后,那么寻找变量时候就会出现顺序,对于上述实例:
当执行console.log(xo)时,其寻找顺序为根据作用域链从内到外的优先级寻找,如果内层没有就逐步向上找,直到没找到抛出异常。

四、JavaScript的作用域链执行前已创建
JavaScript的作用域在被执行之前已经创建,日后再去执行时只需要按照作用域链去寻找即可。
示例一:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 | xo = 'alex';functionFunc(){    varxo = "seven";    functioninner(){        console.log(xo);    }    returninner;}varret = Func();ret();// 输出结果: seven | 
上述代码,在函数被调用之前作用域链已经存在:
- 全局作用域 -> Func函数作用域 -> inner函数作用域
当执行【ret();】时,由于其代指的是inner函数,此函数的作用域链在执行之前已经被定义为:全局作用域 -> Func函数作用域 -> inner函数作用域,所以,在执行【ret();】时,会根据已经存在的作用域链去寻找变量。
示例二:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | xo = 'alex';functionFunc(){    varxo = "eirc";    functioninner(){        console.log(xo);    }    xo = 'seven';    returninner;}varret = Func();ret();// 输出结果: seven | 
上述代码和示例一的目的相同,也是强调在函数被调用之前作用域链已经存在:
- 全局作用域 -> Func函数作用域 -> inner函数作用域
不同的时,在执行【var ret = Func();】时,Func作用域中的xo变量的值已经由 “eric” 被重置为 “seven”,所以之后再执行【ret();】时,就只能找到“seven”。
示例三:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 | xo = 'alex';<br>functionBar(){    console.log(xo);}functionFunc(){    varxo = "seven";        returnBar;}varret = Func();ret();// 输出结果: alex | 
上述代码,在函数被执行之前已经创建了两条作用域链:
- 全局作用域 -> Bar函数作用域
- 全局作用域 -> Func函数作用域
当执行【ret();】时,ret代指的Bar函数,而Bar函数的作用域链已经存在:全局作用域 -> Bar函数作用域,所以,执行时会根据已经存在的作用域链去寻找。
五、声明提前
在JavaScript中如果不创建变量,直接去使用,则报错:
| 1 2 | console.log(xxoo);// 报错:Uncaught ReferenceError: xxoo is not defined | 
JavaScript中如果创建值而不赋值,则该值为 undefined,如:
| 1 2 3 | varxxoo;console.log(xxoo);// 输出:undefined | 
在函数内如果这么写:
| 1 2 3 4 5 6 7 | functionFoo(){    console.log(xo);    varxo = 'seven';}Foo();// 输出:undefined | 
上述代码,不报错而是输出 undefined,其原因是:JavaScript的函数在被执行之前,会将其中的变量全部声明,而不赋值。所以,相当于上述实例中,函数在“预编译”时,已经执行了var xo;所以上述代码中输出的是undefined。
原文:http://www.cnblogs.com/wupeiqi/p/5649402.html
五句话搞定JavaScript作用域【转】的更多相关文章
- 五句话搞定JavaScript作用域
		JavaScript的作用域一直以来是前端开发中比较难以理解的知识点,对于JavaScript的作用域主要记住几句话,走遍天下都不怕... 一.“JavaScript中无块级作用域” 在Java或C# ... 
- 【】五句话搞定JavaScript作用域
		JavaScript的作用域一直以来是前端开发中比较难以理解的知识点,对于JavaScript的作用域主要记住几句话,走遍天下都不怕... 一.“JavaScript中无块级作用域” 在Java或C# ... 
- 五句话搞定JavaScript作用域(ES5)
		JavaScript的作用域一直以来是前端开发中比较难以理解的知识点,对于JavaScript的作用域主要记住几句话,走遍天下都不怕... 一.“JavaScript中无块级作用域” 在Java或C# ... 
- 160630、五句话搞定JavaScript作用域
		JavaScript的作用域一直以来是前端开发中比较难以理解的知识点,对于JavaScript的作用域主要记住几句话,走遍天下都不怕. 一.“JavaScript中无块级作用域” 在Java或C# ... 
- 【Python之路】特别篇--五句话搞定JavaScript作用域
		JavaScript的作用域一直以来是前端开发中比较难以理解的知识点,对于JavaScript的作用域主要记住几句话,走遍天下都不怕... 一.“JavaScript中无块级作用域” 在Java或C# ... 
- 5句话搞定ES5作用域
		JavaScript的作用域一直以来是前端开发中比较难以理解的知识点,对于JavaScript的作用域主要记住几句话,走遍天下都不怕... 一.“JavaScript中无块级作用域” 在Java或C# ... 
- 五句话搞定Python、JavaScript作用域
		这个银角的看家之作了吧,哈哈哈,剽窃下,原地址在这:点我点我 Python与JavaScript基本相同,但声明提前一项略有不同. JavaScript.Python中无块级作用域 在Java或C#中 ... 
- 我和小美的撸码日记(3)之中的一个句话搞定MVC表单页数据绑定与提交
		另外献上在<线体验Demo地址>希望大家也能从中得到一些启示. 地址:http://121.40.148.178:8080/ . username:guest,password:12345 ... 
- 30秒搞定javascript作用域
		引用一下js权威指南的一名话作为开场”JavaScript中的函数运行在它们被定义的作用域里,而不是它们被执行的作用域里.” javascript不存在大括号级的作用域,但他有函数作用域,也就是说变量 ... 
随机推荐
- Yii 获取url 的一些方法
			原文出处http://blog.csdn.net/iefreer/article/details/21325371 1. 获取url中的host信息: Yii::app()->request-& ... 
- Java虚拟机规范----JVM体系结构
			一.Java平台的结构图 二.JVM与JRE.JDK关系? JVM:Java Virtual Machine(Java虚拟机),负责执行符合规范的Class文件 JRE:Java Runtime En ... 
- IIS中User-mode caching引起的Cache-Control不为public的问题
			在IIS的Output caching中如果启用了User-mode caching将引起Cache-Control为no-cache,从而造成页面不能被浏览器或代理服务器缓存. web.config ... 
- AngularJs:Directive指令用法
			摘自:http://www.jb51.net/article/83051.htm 摘要:Directive(指令)是AngularJ非常强大而有有用的功能之一.它就相当于为我们写了公共的自定义DOM元 ... 
- php中函数preg_match或preg_match_all 第三个参数$match的解释
			理解自:http://www.cnblogs.com/vicenteforever/articles/1623137.html php手册中是这样解释的 matches 如果提供了参数matches, ... 
- 解决Uploadify 3.2上传控件加载导致的GET 404 Not Found问题
			http://www.uploadify.com/forum/#/discussion/7329/uploadify-v3-bug-unecessary-request-when-there-is-n ... 
- logger类
			日志模块logging的四大组件: logger: 志类应用程序往往通调用提供api记录志handler: 志信息处理志发送(保存)同目标域filter: 志信息进行滤formatter:志格式化 L ... 
- Java-idea-Checkstyle自动化代码规范检查
			一.概述 CheckStyle是SourceForge下的一个项目,提供了一个帮助JAVA开发人员遵守某些编码规范的工具.它能够自动化代码规范检查过程,从而使得开发人员从这项重要,但是枯燥的任务中解脱 ... 
- KS检验学习[转载]
			转自:https://wenku.baidu.com/view/ccfa573a3968011ca30091d6.html https://www.cnblogs.com/arkenstone/p/5 ... 
- Scrapy:学习笔记(1)——XPath
			Scrapy:学习笔记(1)——XPath 1.快速开始 XPath是一种可以快速在HTML文档中选择并抽取元素.属性和文本的方法. 在Chrome,打开开发者工具,可以使用$x工具函数来使用XPat ... 
