Javascript中onload載入多個函數執行個體

來源:互聯網
上載者:User

如果直接對winow.onload進行賦值,會覆蓋原來綁定的onload事件。如何能多次綁定了,有下面三種方法
1、將要綁定的事件寫在一塊,然後對onload進行賦值

 代碼如下 複製代碼

window.onload=function(){function1();function2();}

2、通過自訂addLoadEvent來解決

 代碼如下 複製代碼

function addLoadEvent(func){
var oldonload=window.onload;
if(typeof window.onload!=’function’){
window.onload=func;
}else{
window.onload=function(){
oldonload();
func();
}
}
}

添加要載入執行的事件:

 代碼如下 複製代碼

addLoadEvent(func1);
addLoadEvent(func2);

3、要想在你的程式中給一個事件指派多個處理過程的話,只要首先判斷一下瀏覽器,然後根據不同的瀏覽器,選擇使用 attachEvent 還是 addEventListener 就可以了。執行個體如下

 代碼如下 複製代碼

if (document.all) {
window.attachEvent(‘onload’, func1);
window.attachEvent(‘onload’, func2);
} else {
window.addEventListener(‘load’, func1, false);
window.addEventListener(‘load’, func2, false);
}

除了上面方法還有沒有其它辦法呢

用法如下:

 代碼如下 複製代碼

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


window.onload=func;

或者如下:


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

但window.onload 不能同時載入多個函數。

比如:

 代碼如下 複製代碼

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

後面會把前面的覆蓋,上面代碼只會輸出 b。
此時可用如下方法解決:

 代碼如下 複製代碼

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

另一種解決辦法

代碼

 代碼如下 複製代碼

Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/--> function addLoadEvent(func) {
  var oldonload = window.onload;//得到上一個onload事件的函數
  if (typeof window.onload != 'function') {//判斷類型是否為'function',注意typeof返回的是字串
    window.onload = func;
  } else { 
    window.onload = function() {
      oldonload();//調用之前覆蓋的onload事件的函數---->由於我對js瞭解不多,這裡我暫時理解為通過覆蓋onload事件的函數來實現載入多個函數
      func();//調用當前事件函數
    }
  }
}

//(完整樣本)使用如下:

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);
//等價於  window.onload =function() { t();  b(); c() ;}

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


執行多個window.onload產生too much recursion錯誤

,通用的解決方案如下

 代碼如下 複製代碼
 
<script type="text/javascript">
var func = window.onload;
window.onload = function(){
    func ? func() : 0;
    alert(1);
}
</script>

 

這樣的原理就是把window.onload事件一級一級傳遞,保證每一個window.onload事件能執行,但如果出現多次調用而且變數名一樣,就會產生too much recursion錯誤,如下

 代碼如下 複製代碼
 
<script type="text/javascript">
var func = window.onload;
window.onload = function(){
    func ? func() : 0;
    alert(1);
}
 
func = window.onload;
window.onload = function(){
    func ? func() : 0;
    alert(2);
}
</script>

 

上面實現執行兩個window.onload事件,但由於每次傳遞window.onload事件定義為相同的變數名,就會產生too much recursion錯誤。

解決方案
由於產生的原因是因為定義為相同的變數名產生迴圈執行代碼,因此解決方案只需要把變數名定義不同即可解決。如下

 代碼如下 複製代碼
 
<script type="text/javascript">
var func = window.onload;
window.onload = function(){
    func ? func() : 0;
    alert(1);
}
 
func1 = window.onload;
window.onload = function(){
    func1 ? func1() : 0;
    alert(2);
}
</script>

 

Web頁面如果出現多次window.onload事件,盡量能合併作業處理,或實作類別似於jQuery的ready事件機制,解決冗餘代碼問題,提高代碼的可讀性。

更多詳細內容請查看:http://www.111cn.net/wy/js-ajax/too-much-recursion.htm

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.