av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

javascript - window.onload被覆蓋,怎么解決?

瀏覽:178日期:2023-05-25 17:45:41

問題描述

window.onload = function(){ var para =document.createElement('p'); var info = 'NodeName:'; info += para.nodeName; info += ' NodeType:'; info += para.nodeType; alert(info); } window.onload = function(){ var para = document.getElementById('testid'); var e = document.createElement('p'); var txt = document.createTextNode('hello zmz'); para.appendChild(e); e.appendChild(txt); }

只執行了第二個window.onload,但是我想讓兩個window.onload都執行。該怎么處理?

問題解答

回答1:

我們都知道onload事件只能執行一次,所以假設你要運行兩個onload時候執行的函數,最后只能執行后一個onload事件的函數,那么我們如何執行多個onload事件的函數呢,形式如下:

window.onload = function(){num1();num2();}

所以,我們就頂一個函數addLoadEvent(func),它只接受參數,就是在頁面加載完畢時執行的函數的名字

function addLoadEvent(func){ var oldonload = window.onload; //把現在有window.onload事件處理函數的值存入變量oldonload。 if(typeof window.onload != ’function’){ //如果這個處理函數還沒有綁定任何函數,就像平時那樣把新函數添加給它 window.onload = func; }else{ //如果在這個處理函數上已經綁定了一些函數。就把新函數追加到現有指令的末尾 window.onload = function(){ oldonload(); func(); } } }

調用:

addLoadEvent(num1);addLoadEvent(num2);回答2:

window.addEventListener(’load’,function(e){state1},false);window.addEventListener(’load’,function(e){state2},false);不建議用onload

回答3:

建議 一個頁面就一個window.onload

window.onload = function(){ var para =document.createElement('p'); var info = 'NodeName:'; info += para.nodeName; info += ' NodeType:'; info += para.nodeType; alert(info); var para = document.getElementById('testid'); var e = document.createElement('p'); var txt = document.createTextNode('hello zmz'); para.appendChild(e); e.appendChild(txt); }

如果怕命名沖突,可用封閉空間

window.onload = function(){ (function(){var para =document.createElement('p'); var info = 'NodeName:'; info += para.nodeName; info += ' NodeType:'; info += para.nodeType; alert(info); })();(function(){var para = document.getElementById('testid'); var e = document.createElement('p'); var txt = document.createTextNode('hello zmz'); para.appendChild(e); e.appendChild(txt); })();} 回答4:

方法1

function fn1(){ var para =document.createElement('p'); var info = 'NodeName:'; info += para.nodeName; info += ' NodeType:'; info += para.nodeType; alert(info); }function fn2(){ var para = document.getElementById('testid'); var e = document.createElement('p'); var txt = document.createTextNode('hello zmz'); para.appendChild(e); e.appendChild(txt); }window.onload = function(){ fn1(); fn2();}

方法2是用樓上的方法。

window.addEventListener(’load’,function(e){fn1();},false);window.addEventListener(’load’,function(e){fn2();},false);

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 亚洲久草| 久久伊| 日韩在线免费播放 | 中文字幕欧美日韩一区 | 日本成人一区二区 | 成人毛片网 | 毛片网在线观看 | 久草视频在线播放 | 韩国主播午夜大尺度福利 | 欧美日韩看片 | 亚洲精品免费视频 | 国产一区精品 | 久久精品免费观看 | h片在线看 | 在线成人福利 | 色接久久 | av天天澡天天爽天天av | 日韩一区二区三区精品 | av一区在线观看 | 最新国产在线 | 玖玖视频网 | 99成人| 天天色天天射天天干 | 成人欧美一区二区三区在线播放 | 久久中文一区二区 | 欧美日韩在线视频一区 | 国产精品99 | 欧美成人精品一区二区三区 | 欧美中文字幕一区二区三区 | 久久精品国产一区二区三区 | 成年视频在线观看福利资源 | 亚洲欧美日韩久久久 | 男女视频免费 | 亚洲国产成人精品女人久久久野战 | 99亚洲视频 | 91天堂网| 国产丝袜人妖cd露出 | 久久国产欧美日韩精品 | 午夜一区二区三区视频 | 国产 日韩 欧美 在线 | 欧美一a |