时间:2021-05-26
本文实例讲述了JavaScript变量声明提升。分享给大家供大家参考,具体如下:
如下代码输出的结果是?
var num = 123;function foo1(){ console.log( num ); //undefined var num = 456; console.log( num ); //456}foo1();Javascript代码执行分为两个大步:
预解析的过程
代码的执行过程
程序在执行过程中,会先将代码读取到内存中检查,会将所有的声明在此进行标记,所谓的标记就是让JS解析器知道有这个名字,后面在使用名字的时候不会出现未定义的错误。这个标记过程就是提升。
声明:
名字的声明,标识符声明(变量名声明)
函数的声明
函数声明与函数表达式有区别,函数声明是单独写在一个结构中,不存在任何语句,逻辑判断等结构中
function f() {}function func() { // 函数声明} if ( true ) { function func2 () {} //函数表达式}var f = function func3 () {}; //函数表达式this.sayHello = function () {}; //函数表达式var i= 1;function func4 () {} // 函数声明 var j = 2;}首先函数声明告诉解析器有这个名字存在,该阶段与名字声明一样
告诉解析器,这个名字对应的函数体是什么
分析
预解析代码,提示名字
开始执行代码,第一句话从赋值语句开始执行
执行函数调用
首先,预解析,读取提升 a ,有一个名字 a 存在了
其次,in 运算符:判断某一个字符串描述的属性名是否在对象中
执行第一个判断:! 'a' in window
最后,打印结果 a 的值为 undefined
预解析:提升 f1 函数,只保留提升后的内容,所以打印是 false
执行代码,第一句话就是一个空的if结构
if ( true ) {} else {}执行函数调用,得到 false
上面的语法是声明,可以提升,因此在函数上方也可以调用
下面的语法是函数表达式,函数名就是foo ,他会提升,提升的不是函数体
函数表达式也是支持名字语法
var foo = function func1 () {};func();函数有一个属性name,表示的是函数名,只有带有名字的函数定义,才会有name属性值,否则是“”
新的浏览器中,写在if、while、do..while结构中的函数,都会将函数的声明转换成特殊的函数表达式
将代码
转换成
if (...) { var foo = function foo () { .... }}完。
感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.jb51.net/code/HtmlJsRun测试上述代码运行效果。
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了JavaScript变量提升和严格模式。分享给大家供大家参考,具体如下:1.什么是变量提升所谓的变量提升指的是:函数声明和变量声明总是会被解释器悄
本文实例讲述了JavaScript的变量声明与声明提前用法。分享给大家供大家参考,具体如下:JavaScript的变量声明JavaScript的变量声明语句无论
变量提升JavaScript的变量提升有两种,用var声明的变量以及用function声明的变量。用var声明的变量我们先来看下面这段代码,a的值是多少代码1c
hoisting机制javascript的变量声明具有hoisting机制,JavaScript引擎在执行的时候,会把所有变量的声明都提升到当前作用域的最前面。
本文实例讲述了弱类型语言javascript开发中的一些坑。分享给大家供大家参考,具体如下:测试1:(未声明变量自动提升为全局变量)test1();functi