在 Google 的 Chrome 浏览器中运行我的(相当复杂的)JavaScript/jQuery 应用程序,它会$(document).ready
在一些 JavaScript 文件尚未加载时触发。
相关代码(简化):
在我的 HTML 文件中
<script>var httpRoot='../../../';var verifyLoad = {};</script>
<script src="../../../globalvars.js"></script>
<script src="../../../storagekeys.js"></script>
<script src="../../../geometry.js"></script>
<script src="../../../md5.js"></script>
<script src="../../../serialize.js"></script>
...
<script src="../../../main.js"></script>
作为除 main.js 之外的每个 .js 文件的最后一条语句:
verifyLoad.FOO = true; // where FOO is a property specific to the file
例如
verifyLoad.jquerySupplements = true;
verifyLoad.serialize = true;
在 main.js 中:
$(document).ready(function() {
function verifyLoadTest (scriptFileName, token) {
if (!verifyLoad.hasOwnProperty(token)) {
console.log(scriptFileName + ' not properly loaded');
};
};
verifyLoadTest('globalvars.js', 'globalvars');
verifyLoadTest('storagekeys.js', 'storagekeys');
verifyLoadTest('geometry.js', 'geometry');
verifyLoadTest('md5.js', 'geometry');
verifyLoadTest('serialize.js', 'serialize');
...
}
令我惊讶的是,我看到了其中一些触发器。这与我的理解不符$(document).ready
。我错过了什么?