久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

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

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

瀏覽:207日期: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
相關文章:
主站蜘蛛池模板: 丘北县| 错那县| 寻甸| 保靖县| 读书| 丰宁| 工布江达县| 江山市| 保亭| 金门县| 孟村| 横峰县| 宜川县| 日照市| 宣汉县| 肇源县| 天全县| 墨竹工卡县| 五寨县| 什邡市| 吉隆县| 玉树县| 汉中市| 紫阳县| 师宗县| 囊谦县| 连州市| 思南县| 耒阳市| 益阳市| 淮北市| 菏泽市| 乌拉特后旗| 浦江县| 五家渠市| 潮州市| 扎鲁特旗| 江达县| 义马市| 赤城县| 屏南县|