欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js window.onload 加載多個(gè)函數(shù)和追加函數(shù)詳解

 更新時(shí)間:2014年01月08日 09:09:06   作者:  
本篇文章主要是對js window.onload 加載多個(gè)函數(shù)和追加函數(shù)進(jìn)行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助

平時(shí)做項(xiàng)目 經(jīng)常需要使用window.onload,

用法如下:

function func(){alert("this is window onload event!");return;}

window.onload=func;

或者如下:

window.onload=function(){alert("this is window onload event!");return;}

但window.onload 不能同時(shí)加載多個(gè)函數(shù)。

比如:

function t(){
alert("t")
}
function b(){
alert("b")
}
window.onload =t ;
window.onload =b ;

后面會把前面的覆蓋,上面代碼只會輸出 b。

此時(shí)可用如下方法解決:
window.onload =function() { t();  b(); }

另一種解決方法如下:

復(fù)制代碼 代碼如下:

 function addLoadEvent(func) {
  var oldonload = window.onload;//得到上一個(gè)onload事件的函數(shù)
  if (typeof window.onload != 'function') {//判斷類型是否為'function',注意typeof返回的是字符串
    window.onload = func;
  } else { 
    window.onload = function() {
      oldonload();//調(diào)用之前覆蓋的onload事件的函數(shù)---->由于我對js了解不多,這里我暫時(shí)理解為通過覆蓋onload事件的函數(shù)來實(shí)現(xiàn)加載多個(gè)函數(shù)
      func();//調(diào)用當(dāng)前事件函數(shù)
    }
  }
}

//(完整示例)使用如下:

function t(){
alert("t")
}
function b(){
alert("b")
}
function c(){
alert("c")
}
 function addLoadEvent(func) {
  var oldonload = window.onload;
  if (typeof window.onload != 'function') {
    window.onload = func;
  } else { 
    window.onload = function() {
      oldonload();
      func();
    }
  }
}

addLoadEvent(t);
addLoadEvent(b);
addLoadEvent(c);
//等價(jià)于  window.onload =function() { t();  b(); c() ;}


個(gè)人以為直接使用隱式函數(shù)(如:window.onload =function() { t();  b(); c() ;})更快捷,當(dāng)然使用 addLoadEvent 更professional,各取所好吧!

JS window.onload追加函數(shù):

復(fù)制代碼 代碼如下:

<script>
if(window.attachEvent)//IE:如果瀏覽器中存在window.attachEvent函數(shù)則使用window.attachEvent函數(shù),判斷是否是IE還可以使用:if (document.all){//..}
window.attachEvent("onload",function() {alert("add method");});
else  //FireFox
window.addEventListener("load",function() {alert("add method");},true);
</script>

運(yùn)行,js中alert彈出消息,問題解決。

============相關(guān)資料================

attachEvent   將指定函數(shù)綁定到事件,以便每當(dāng)該事件在對象上觸發(fā)時(shí)都調(diào)用該函數(shù)。

Internet Explorer 從 5.0 開始提供了一個(gè) attachEvent 方法,使用這個(gè)方法,就可以給一個(gè)事件指派多個(gè)處理過程了。attachEvent 對于目前的 Opera 也適用。但是 Mozilla/Firefox 并不支持這個(gè)方法。但是它支持另一個(gè) addEventListener 方法,這個(gè)方法跟 attachEvent 差不多,也是用來給一個(gè)事件指派多個(gè)處理過程的。但是它們指派的事件有些區(qū)別,在 attachEvent 方法中,事件是以 “on” 開頭的,而在 addEventListener 中,事件沒有開頭的 “on”,另外 addEventListener 還有第三個(gè)參數(shù),一般這個(gè)參數(shù)指定為 false 就可以了。

相關(guān)文章

最新評論