是否可以同步调用 .js
文件,然后立即使用它?
<script type="text/javascript">
var head = document.getElementsByTagName('head').item(0);
var script = document.createElement('script');
script.setAttribute('type', 'text/javascript');
script.setAttribute('src', 'http://mysite/my.js');
head.appendChild(script);
myFunction(); // Fails because it hasn't loaded from my.js yet.
window.onload = function() {
// Works most of the time but not all of the time.
// Especially if my.js injects another script that contains myFunction().
myFunction();
};
</script>
这很简单。在我的实现中,createElement 的东西在一个函数中。我考虑过在函数中添加一些东西,以便在返回控制权之前检查某个变量是否被实例化。但是当包含来自另一个我无法控制的站点的 js 时,仍然存在一个问题。
有什么想法吗?
编辑:
我现在已经接受了最好的答案,因为它对正在发生的事情给出了一个很好的解释。但是,如果有人有任何建议,如何改善这一点,我开放给他们。这是我想做的一个例子。
// Include() is a custom function to import js.
Include('my1.js');
Include('my2.js');
myFunc1('blarg');
myFunc2('bleet');
我只是想避免过多地了解内部原理,并且能够说,“我希望使用这个模块,现在我将使用它的一些代码。”