Javascript - Alle von der Seite eingeführten JS-Dateien, jede JS-Datei verfügt über window.onload. Gelegentlich wird eine bestimmte JS-Datei nicht ausgeführt.
習慣沉默
習慣沉默 2017-06-26 10:55:06
0
5
923

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? ?

習慣沉默
習慣沉默

Antworte allen(5)
phpcn_u1582

window.onload只有一次,所以会出现多个js同时使用它而冲突的问题。
解决办法

1.用jQuery使用ready()方法替换onload
2.在window.onload中一次加载所有js文件,例:window.onload=function(){function(a);function(b);} 
黄舟

我试了一下,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();
            }
        }
    }
大家讲道理
  • 通过window.onload = function() { ... }方法设置的事件,后面的window.onload值会覆盖掉前面的,所以,只有最后一次生效。(这个和调用a = 1; a = 2; a =3;是一个道理)

  • 如果需要对windowonload事件进行多次绑定,建议使用addEventListener

window.addEventListener('load', function() { ... }, false);
  • 注意,ID中使用attachEvent而非addEventListener

window.attachEvent('onload', function() { ... });
  • 另外注意,addEventListener中用的是'load',而attachEvent中用的是'onload'

世界只因有你

window.onload()方法只能绑定一次的,多次绑定只有最后一次生效

代言

window.onload只会调用最后一个的,之前的都会被覆盖掉。

Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage