[英]Accessing global function inside js in html page on IE9
我正在尝试访问我在main.js文件中声明的全局函数,并尝试在html页面中使用它:
<!DOCTYPE html>
<html>
<head>
</head>
<body>
<script src='main.js'></script>
<script>
(function(){
window.myFunction();
})();
</script>
</body>
</html>
还有我的main.js文件
(function(){
window.myFunction = function(){
alert(1);
}
})();
这适用于所有浏览器,但IE9并没有测试其他IE版本。 你觉得我做错了什么? 或者它与IE有什么关系?
你应该在main.js中传递这样的window对象
(function(w){
w.myFunction = function(){
alert(1);
}
})(window);
“()”中的函数关键字后面的变量是函数内部传递参数的别名,而封装函数末尾的“()”内的变量是传递的实变量。
演示: http : //codepen.io/anon/pen/aOgZdB - 已在IE中尝试过。
我认为你可以直接将函数绑定到窗口的另一件事,你不需要把它放在封装函数中,如:
window.myFunction=function(){
alert(1);
}
在你的main.js中没有封装它。
尝试这个:
<!DOCTYPE html>
<html>
<head>
</head>
<body>
<script src='main.js'></script>
<script>
window.myFunction();
</script>
</body>
</html>
我没有IE 9,所以我不知道它是否有效。 但在IE 11中测试过。
(function(window){
window.myFunction = function(){
alert(1);
}
})(window);
(function(){
window.myFunction();
})();
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.