Heim > Fragen und Antworten > Hauptteil
1. Führen Sie a.js und b.js auf Seite A ein. Es gibt kein Problem mit a.js und b.js, wenn Sie window.onload verwenden.
Aber ich führe auch a.js und c.js auf Seite B ein Gelegentlich sieht eine .js so aus, als ob sie überhaupt nicht ausgeführt würde. Aber ich habe den Inhalt von window.onload in a.js direkt in den Onload von c.js auf Seite B eingefügt, und ich weiß es nicht was ist los? ?
phpcn_u15822017-06-26 10:57:06
window.onload只有一次,所以会出现多个js同时使用它而冲突的问题。
解决办法
1.用jQuery使用ready()方法替换onload
2.在window.onload中一次加载所有js文件,例:window.onload=function(){function(a);function(b);}
黄舟2017-06-26 10:57:06
我试了一下,window可以绑定多次,但是最后一次才会生效,你可以对照看下我下面的2个例子来理解你出现的情况。
//方式1:
window.onload=function () {
console.log("1");
}
window.onload=function () {
console.log("2");
}
// 输出2
// -------------------------------分割线
// 方式2:
function fn1() {
console.log("1");
}
function fn2() {
console.log("2");
}
addEventLoad(fn1);
addEventLoad(fn2);
//输出1 2
function addEventLoad(fn){
var oldFn = window.onload;
if(typeof window.onload != 'function'){
window.onload = fn;
}else{
window.onload = function(){
oldFn();
fn();
}
}
}
大家讲道理2017-06-26 10:57:06
通过window.onload = function() { ... }
方法设置的事件,后面的window.onload
值会覆盖掉前面的,所以,只有最后一次生效。(这个和调用a = 1; a = 2; a =3;
是一个道理)
如果需要对window
的onload
事件进行多次绑定,建议使用addEventListener
:
window.addEventListener('load', function() { ... }, false);
注意,ID中使用attachEvent
而非addEventListener
:
window.attachEvent('onload', function() { ... });
另外注意,addEventListener
中用的是'load'
,而attachEvent
中用的是'onload'
。