JavaScript—详细介绍作用域,作用域链和预解析
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了JavaScript—详细介绍作用域,作用域链和预解析,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1366字,纯文字阅读大概需要2分钟。
内容图文
![JavaScript—详细介绍作用域,作用域链和预解析](/upload/InfoBanner/zyjiaocheng/286/0011373c6d92467981d752336b2c889c.jpg)
在JAvaScript中,函数中定义的变量是局部变量
作用域:就是变量的使用范围,
分为:局部作用域和全局作用域
js中没有块级作用域---一对括号中定义的变量,这个变量可以在大括号外面使用
作用域链:变量的使用,从里向外,层层的搜索,搜索到了就可以直接使用了
var num=10; //作用域链 级别:0 var num2=20; var str = "abc" function f1() { var num2=20; function f2() { var num3=30; console.log(num); } f2(); } f1();
层层搜索,搜索到0级作用域的时候,如果还是没有找到这个变量,结果就是报错
预解析:就是在浏览器解析代码之前,把变量的声明和函数的声明提前(提升)到该作用域的最上面
(1)变量的提升
下面这种情况,变量的声明被提前了,但是num的值并没有提前,结果为undefined
//变量的提升 console.log(num); var num=100; //提升之后为: var num;//变量的声明提前 console.log(num); var num=100;
(2)
函数声明被提前,代码仍然可以执行
//函数的声明被提前了 f1(); function f1() { console.log("这个函数,执行了"); }
但是对于下面这种情况,代码报错
f2(); var f2=function () { console.log("小杨好帅哦"); } //声明提前后: var f2;//为一个变量,undefind f2();//undefind加括号是不被认可的,所以报错 var f2=function () { console.log("小杨好帅哦"); }
要想不报错,代码可以改为:
var f2; f2=function () { console.log("小杨好帅哦"); }; f2();
相关文章:
聊一聊JavaScript作用域和作用域链
JavaScript作用域与作用域链深入解析
相关视频:
玩转javascript之三级联动实例
以上就是JavaScript—详细介绍作用域,作用域链和预解析的详细内容,更多请关注Gxl网其它相关文章!
内容总结
以上是互联网集市为您收集整理的JavaScript—详细介绍作用域,作用域链和预解析全部内容,希望文章能够帮你解决JavaScript—详细介绍作用域,作用域链和预解析所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。