I'我用setTimeout加载脚本,你能找到一个更快的方法吗
I'm loading scripts with setTimeout, can you find a faster way?
我有一个名为main.min.js的文件。这个文件有一些部分需要库pixi.min.js。我能想出的加载这两个部分的最快方法是:
HTML
<script async src="//cdnjs.cloudflare.com/ajax/libs/pixi.js/3.0.11/pixi.min.js"></script>
<script async src="static/js/main.min.js"></script>
JAVASCRIPT
function waitForJS() {
var shouldStop;
if (typeof window.PIXI !== "undefined") {
shouldStop = true;
}
if (shouldStop === true) {
//PIXI has loaded
ThePixiFunction();
return;
}
setTimeout(waitForJS,30);
} waitForJS();
我认为这是(对我来说)最快的方法的原因是,两个文件同时开始加载,但main.min.js在PIXI加载之前就开始执行,只有需要PIXI的函数在等待它。这是不是有我忽略的地方?或者有没有更好的方法来加载这两个文件?
您可以将调用Pixi相关行为的调用拆分到一个单独的文件中,然后正常加载它们:
<script src="static/js/main.min.js"></script>
<script src="//cdnjs.cloudflare.com/ajax/libs/pixi.js/3.0.11/pixi.min.js"></script>
<script src="static/js/invokePIXIfunction.min.js></script>
原来这很愚蠢,我找到了一种新方法:
HTML
<script src="static/js/main.min.js"></script>
<script src="//cdnjs.cloudflare.com/ajax/libs/pixi.js/3.0.11/pixi.min.js" onload="PIXILoaded();"></script>
JS(在main.min.JS中)
window.PIXILoaded = function() {
initPixiFunction();
};
请注意,您应该避免全局
相关文章:
- 将一个方法转换为promise:Nodejs
- 如何在所有ng点击事件AngularJS上启动一个方法
- 创建一个方法,通过一个窗口进行迭代并获取Titanium中的所有控件
- 如何创建一个方法来验证数组的范围
- 如何将一个方法延迟到另一个方法首先完成,javascript
- 在Javascript中对类的每个实例调用一个方法
- 如何重写一个方法,并且仍然能够在重写的方法中使用基方法
- NodeJS-从同一文件中的另一个方法调用一个方法
- 有没有任何情况下,一个方法不应该是原型方法
- Jasmine间谍的函数称为一个方法
- 在带有参数列表的表单submit上调用一个方法
- 方法不在另一个方法内部调用
- 在 1 个方法中增加变量值会触发另一个方法的 for 循环,欢迎任何建议
- 如何使用javascript express node将变量从控制器中的一个方法公开.js到另一个控制器.js
- 如何在javascript中将变量的值分配给另一个方法
- 在浏览器关闭时,单击确认对话框中的“停留在页面上”,执行一个方法
- 使用一个方法在c#中启动其他方法
- 如何在Ember中转换到另一个路由时调用一个方法
- 在typescript中重载一个方法
- 我可以在setInterval函数中放入一个方法作为参数吗