ファイルを同期的に呼び出し、.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');
内部構造を知りすぎないようにして、「このモジュールを使用したいので、そのモジュールのコードを使用します」とだけ言えるようにしたいだけです。