JS学习2--关于预解释
2015-08-04 10:22
351 查看
<pre style="font-family: 'Source Code Pro'; font-size: 12pt; background-color: rgb(255, 255, 255);"><pre name="code" class="javascript">var f=function (){ alert("1")} function f(){alert("@")}; f();关于这两种定义的解释:第一种 即 定义了一个变量并给其赋值为function,归根到底在于解释中声明的为变量;第二站 即定义了一个函数f;函数在预解释中是声明加定义;关于预解释即在代码顺序执行之前,会先将带var 提前声明跟带function的提前声明加定义,值得注意的是带var的只是声明了并没有定义,变量的定义是在代码顺序执行时完成的。上述执行之后弹出的是1,而不是2;因为
第一行的f是个变量,在预解释的过程中,只是声明了,并没有定义,即这一行代码是在代码顺序执行时才完成的第二行是在预解释中提前完成的;还有一点值得注意的是,在预解释中,如果遇到相同名称的变量,是不会重新声明的,带上会重新定义;有一段有趣的代码如下:
function a(){}; var a; alert(a);
弹出的是function a(){}
var a=9;
function a(){}; alert(a);
弹出的是9而不是function;函数的声明加定义是在预解释中就完成了,如果再次遇到就不再执行;
相关文章推荐
- 深入理解javascript之函数
- JS中cookie的基本使用
- js判断出两个字符串最大子串的函数
- JavaScript中模拟实现Java的集合类Map的常用方
- Difference between Properties and Attributes in JavaScript
- js之iframe子页面与父页面通信
- Javascript实现鼠标右键特色菜单
- Javascript模块化编程(二):AMD规范
- 常用的Javascript数据验证插件
- js事件委托
- Emberjs笔记
- Jsoup学习笔记9:Jsoup 解析saz文件,读取其中的htm文件到字符串,提取字符串中的数据写入csv文件中
- JSP的基本原理
- 不一样的dynamic解析json 万能方法
- 关于EmberJs的一些规范
- 关于EmberJs的一些规范
- 关于EmberJs的一些规范
- javascript杂记
- JSTL(fn函数)
- javascript中的正则表达式