加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Dojo对不同浏览器(IE, Firefox)下JavaScript变量作用范围的影响

发布时间:2020-12-16 22:05:32 所属栏目:百科 来源:网络整理
导读:关于JavaScript变量的作用范围,前面已经有很多文章谈论到。比如"JavaScript tutorial: Variable scope and the var keyword "区分了var在不同上下文中对变量作用范围的影响。 然而采用独立JS文件并引入dojo.provide/require机制后,情况就变得比较有趣了。

关于JavaScript变量的作用范围,前面已经有很多文章谈论到。比如"JavaScript tutorial: Variable scope and the var keyword "区分了var在不同上下文中对变量作用范围的影响。

然而采用独立JS文件并引入dojo.provide/require机制后,情况就变得比较有趣了。

测试的server-side文件结构如下:

其中,a.js为未使用dojo.provide声明的文件,在test.html中通过script-src调用。




c.js使用dojo.provide声明,在test.html中通过dojo.require调用。
test.html具体如下: <html> <head> <script type="text/javascript" src="/site_media/js/dojoroot/dojo/dojo.js.uncompressed.js""></script> <script type="text/javascript" src="/site_media/js/my/a.js" ></script> <script type="text/javascript"> dojo.registerModulePath("my","/site_media/js/my"); dojo.require("my.c"); </script> </head> <body> <script type="text/javascript"> a1 += 1; a2 += 1; c2 += 1; c1 += 1; </script> </body> </html> 1. Firefox 运行test.html后,在firebug console可以看到a1,a2,c1,c2的值都变成2了。符合变量作用范围的一般规则。 2. IE 运行test.html后,报错找不到c1。其他变量都变成了2。 由此看来,在dojo.provide声明的JS文件中,用var定义的变量在IE中并不被看作是全局变量;而在Firefox中却可以作为全局变量。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读