JavaScript判斷頁面加載完之后再執(zhí)行預定函數(shù)的技巧
來源:易賢網(wǎng) 閱讀:834 次 日期:2016-06-27 15:47:44
溫馨提示:易賢網(wǎng)小編為您整理了“JavaScript判斷頁面加載完之后再執(zhí)行預定函數(shù)的技巧”,方便廣大網(wǎng)友查閱!

這篇文章主要介紹了JavaScript判斷頁面加載完之后再執(zhí)行預定函數(shù)的技巧,原理還是利用監(jiān)聽器監(jiān)聽元素事件、被觸發(fā)則執(zhí)行函數(shù),需要的朋友可以參考下

JavaScript 腳本語言的執(zhí)行,是需要觸發(fā)的。一般的做法就是在網(wǎng)頁中,直接編寫幾個函數(shù),有的在代碼被加載的時候就被瀏覽器處理,或者使用類似下面的代碼來觸發(fā)實現(xiàn)函數(shù)的相關功能。

<div id=”link” onclick=”fun()” ></div>

上面代碼的意思就是,當鼠標點擊 id 為 link 的元素的時候,就觸發(fā)了它的 onclick 事件,然后執(zhí)行使用 JavaScript 定義的 fun 函數(shù)。這樣的做法肯定是很不合理的,因為觸發(fā)操作直接寫進了 HTML 結(jié)構里面,內(nèi)容和行為沒有隔離開,對日后的二次開發(fā)或者修改帶來不便。

需要注意的是,當事件處理與對應元素綁定起來的時候,只有在那個元素加載完之后才能進行操作。如果說把處理的腳本放在了 head 區(qū)域,瀏覽器會報錯。因為下面的 HTML 元素還沒有加載出來,head 中的處理腳本已經(jīng)被處理了。

一個好的執(zhí)行 JavaScript 代碼的方法應該是 行為內(nèi)容分離的、在頁面加載后處理 的。所以,處理 JavaScript 代碼我們要用到 監(jiān)聽器 和 window 對象的 load 事件。

監(jiān)聽器

監(jiān)聽器實際上的功能就是行為與內(nèi)容分離的。以前需要在 HTML 中加上一些觸發(fā)事件來觸發(fā) JavaScript 的相關函數(shù),而現(xiàn)在直接在 JavaScript 中對某個元素的使用監(jiān)聽器,監(jiān)聽這個元素的事件,如果這個元素被觸發(fā)了某些事件,在監(jiān)聽器中又定義了這個事件對應的處理函數(shù),那么就會處理這個函數(shù)。

W3C 的標準方法叫做 addEventListener ,被IE9,chrome,firefox,opera所支持,寫法:

window.addEventListener(‘load',function,false);

早期 IE 中有 attachEvent 方法效果類似:

window.attachEvent(‘onload',function);

使用監(jiān)聽器的方法也很簡單,就是先獲取頁面中的某個元素,然后對這個元素使用監(jiān)聽器,定義監(jiān)聽的事件和對應的事件處理函數(shù),就上文例子:

document.getElementById(‘link').addEventListener(‘click',fun,false);

關于監(jiān)聽器更加詳細的使用說明,請見文末補充資料。

window.onload 事件

onload 事件只有在整個頁面已經(jīng)完全載入的時候才會被觸發(fā),我們將 JavaScript 代碼寫進 onload 事件中,就可以保證在 HTML 元素被加載完成之后,瀏覽器才會處理我們的 JavaScript 代碼。基礎的寫法:

window.onload = function(){

 //code

}

這樣,這個函數(shù)里面的 code 會在加載完成之后被處理。但是,這種方法有個缺陷,就是只能用于這一個函數(shù)。頁面中無法出現(xiàn)多個 window.onload 事件,如果出現(xiàn)了多個 onload 事件,那么后面的內(nèi)容會覆蓋前面的。

那么,我們可以這樣做,在一個 window.onload 事件中,寫上所有需要加載的函數(shù)名,然后在外面定義函數(shù):

window.onload = function(){

  func1();

  func2();

 }

function func1(){…}

function func2(){…}

這樣做雖然可以,但是很不方便,因為我們需要把所有要加載的函數(shù)名都寫進去,修改起來就會很麻煩。當然辦法肯定是有的,jQuery 就特別提供了很強大的多腳本加載方法,那么原生的 JavaScript 肯定也有辦法。

window.onload 同時處理多個函數(shù)

我們需要編寫一個處理函數(shù),先看一下代碼:

function addLoadListener(fn){

  if (typeof window.addEventListener != ‘undefined'){

    window.addEventListener(‘load',fn,false);

  }else if(typeof document.addEventListener != ‘undefined'){

    document.addEventListener(‘load',fn,false);

  }else if (typeof window.attachEvent != ‘undefined'){

    window.attachEvent(‘onload',fn);

  }else{

    var oldfn = window.onload;

    if(typeof window.onload != ‘function'){

      window.onload = fn;

    }else{

      window.onload = function(){

        oldfn();

        fn();

      };

    }

  }

}

簡單的來解析一下,這個自定義的 addLoadListener 函數(shù),傳遞一個 函數(shù)名稱 作為參數(shù)。它首先判斷瀏覽器是否支持相關的 監(jiān)聽器,如果支持 監(jiān)聽器,就使用 監(jiān)聽器 監(jiān)聽 window 對象的 onload 事件,然后處理這個函數(shù)。這段代碼使用 if 語句判斷了所有瀏覽器的監(jiān)聽事件,是跨瀏覽器兼容的。

我們把這段代碼放在 JavaScript 代碼段的最上面,然后在下面定義相關函數(shù),然后使用下面語句來加載 JavaScript 函數(shù)了。

addLoadListener(func);

function func() {…}

這樣,有什么 JavaScript 函數(shù)是需要在頁面加載完成之后處理的,直接使用 addLoadListener 函數(shù)即可,而且可以使用多個。通常來說,所有的 JavaScript 最好都使用 onload 事件加載,以避免意外情況發(fā)生。

更多信息請查看網(wǎng)絡編程

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網(wǎng)