What happens if multiple scripts set [removed]?

前端 未结 4 1070
灰色年华
灰色年华 2021-01-24 00:41

There are a number of posts on StackOverflow and other websites regarding the problem of avoiding namespace collisions. In my scenario, I just want a method in my JavaScript to

相关标签:
4条回答
  • 2021-01-24 01:21

    Yes, the last one will overwrite the previous ones.

    The solution: use the new event API: addEventListener.

    0 讨论(0)
  • 2021-01-24 01:25

    It'll be overriden . In Javascript, when you define handle event like

    window.onload = function(){
       console.log("in Load function 1");
    
    };
    window.onload = function(){
      console.log(" In load function 2");
    };
    

    That will make an " assign " window.onload => function() . And window.onload will be assign to last function .

    But in jQuery, You can handle event in many times and the browser will make all

    $("body").on("click",function(){
    console.log("make a callback function 1");
    });
    $("body").on("click",function(){
    console.log("make a callback function 2");
    });
    

    Because jQuery make a callback not "assign". Hope it helps you.

    0 讨论(0)
  • 2021-01-24 01:26

    This is a fine Javascript way to do it right

    function addLoadEvent(func) {
     var oldonload = window.onload;
     if (typeof window.onload != 'function') {
        window.onload = func;
     } else {
        window.onload = function() {
        if (oldonload) {
          oldonload();
        }
        func();
       }
     }
    }
    addLoadEvent(nameOfSomeFunctionToRunOnPageLoad);
    addLoadEvent(function() {
       /* more code to run on page load */
    });
    

    Explained Source

    0 讨论(0)
  • 2021-01-24 01:29

    There's lots of information on this, but here's the short version:

    if you want to play nicely with onload, you can do

    var prev_onLoad = window.onload;
    window.onload = function() {
        if (typeof(prev_onLoad)=='function')
            prev_onLoad();
    
        // rest of your onLoad handler goes here
    }
    

    and hope that other's play nicely or make sure that's the last setting of onload in the code.

    However, more modern browsers have event registration functions (addEventListener and attachEvent on IE) which take care of this chaining among other things. Quite a few cross-browser onload event functions have been written which take care of this logic for you.

    0 讨论(0)
提交回复
热议问题