少年阿賓

          那些青春的歲月

            BlogJava :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
            500 Posts :: 0 Stories :: 135 Comments :: 0 Trackbacks

          window的load事件會在頁面中的一切都加載完畢時觸發(fā),但這個過程可能會因為要加載外部資源過多而頗費周折。而DOMContentLoaded事件則在形成完整的DOM樹之后就會觸發(fā),不理會圖像、JavaScript文件、CSS文件或其他資源是否已經(jīng)下載完畢。與load事件不同,DOMContentLoaded支持在頁面下載的早期添加事件處理程序,這也就意味著用戶能夠盡早地與頁面進行交互。

          要處理DOMContentLoaded事件,可以為document或window添加相應(yīng)的事件處理程序(盡管這個事件會冒泡到window,但它的目標實際上是document)。來看下面的例子:


          var EventUtil = {
              addHandler
          : function (element, type, handler) {
                 
          if (element.addEventListener) {
                      element
          .addEventListener(type, handler, false);
                 
          } else if (element.attachEvent) {
                      element
          .attachEvent("on" + type, handler);
                 
          } else {
                      element
          ["on" + type] = handler;
                 
          }
             
          }
          };
          EventUtil.addHandler(document, "DOMContentLoaded", function (event) {
              alert
          ("Content loaded.");
          });



          DOMContentLoaded事件對象不會提供任何額外的信息(其target屬性是document)。
          Firefox、Chrome、Safari 3.1及更高的版本和Opera 9及更高版本都支持DOMContentLoaded事件,通常這個事件既可以添加事件處理程序,也可以執(zhí)行其它DOM操作。這個事件始終都會在load事件之前觸發(fā)。

          對于不支持DOMContLoaded的瀏覽器,我們建議在頁面加載期間設(shè)置一個事件為0毫秒的超時調(diào)用,如下面的例子所示:

          sentTimeout(function () {
             
          //在此添加事件處理程序
          }, 0);

          這段代碼實際意思是:“在當前JavaScript處理完成后立即運行這個函數(shù)。”在頁面下載和構(gòu)建期間,只有一個JavaScript處理過程,因此超時調(diào)用會在該過程結(jié)束時立即觸發(fā)。至于這個事件與DOMContentLoaded被觸發(fā)的時間是否同步,主要還是取決與用戶使用的瀏覽器頁面中的其它代碼。為了確保這個方法有效,必須將其作為頁面中的第一個超時調(diào)用;即便如此,也還是無法保證在所有瀏覽器中該超時調(diào)用一定會遭遇load事件被觸發(fā)。



          posted on 2013-07-26 09:39 abin 閱讀(357) 評論(0)  編輯  收藏

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 巴林右旗| 高阳县| 光山县| 济宁市| 三穗县| 南乐县| 海口市| 拉孜县| 平山县| 禹州市| 东乡县| 德惠市| 伊金霍洛旗| 霍林郭勒市| 宁波市| 新民市| 富蕴县| 道真| 尉犁县| 离岛区| 陆川县| 政和县| 密山市| 且末县| 唐河县| 韩城市| 东港市| 绵阳市| 晋州市| 新昌县| 平谷区| 资中县| 麟游县| 平山县| 抚顺县| 尚义县| 淮安市| 五河县| 韩城市| 梁河县| 定西市|