javascript预编译原理和例子
2016-07-22 11:23
288 查看
先看代码:
执行结果是”function”和”variable”。
照理说,一开始,vv有变量声明,有vv函数的函数声明,但vv的函数声明覆盖了变量声明,所以typeof vv为 function.
然后vv被赋值为”variable”。所以,后面一个alert(vv)的结果为:variable。
但当上面的代码变为:
执行结果也一样,这就有蹊跷了!!!说明了,JS解析器是:先预声明变量,再预定义函数 的。
小结一下:JS 在执行前会进行类似”预编译”的操作,而且先预定义变量再预定义函数。
<script> alert( typeof vv); var vv= "variable" ; function vv() { alert( "function vv" ); } alert(vv); </script>
执行结果是”function”和”variable”。
照理说,一开始,vv有变量声明,有vv函数的函数声明,但vv的函数声明覆盖了变量声明,所以typeof vv为 function.
然后vv被赋值为”variable”。所以,后面一个alert(vv)的结果为:variable。
但当上面的代码变为:
<script> alert( typeof vv); function vv() { alert( "function vv" ); } var vv= "variable" ; alert(vv); </script>
执行结果也一样,这就有蹊跷了!!!说明了,JS解析器是:先预声明变量,再预定义函数 的。
小结一下:JS 在执行前会进行类似”预编译”的操作,而且先预定义变量再预定义函数。
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- 最后一次说说闭包
- Ajax
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)
- JavaScript拆分字符串时产生空字符的原因
- Canvas 在高清屏下绘制图片变模糊的解决方法
- Redux系列02:一个炒鸡简单的react+redux例子
- JavaScript 各种遍历方式详解