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

jQuery的文檔處理程序詳解

 更新時間:2016年05月10日 10:23:29   作者:dingyan954  
這篇文章主要介紹了jQuery的文檔處理程序,結(jié)合實例形式詳細(xì)分析了jQuery文檔處理程序的概念、原理、使用方法與相關(guān)注意事項,并詳細(xì)講述了文檔處理程序的優(yōu)勢,需要的朋友可以參考下

本文實例講述了jQuery的文檔處理程序。分享給大家供大家參考,具體如下:

jQuery文檔處理程序

所謂的文檔處理程序,是指jQuery中提供的$(document).ready事件,此事件會在dom加載完畢后觸發(fā),而window.onlaod和body.onload都是在頁面完全加載后觸發(fā)。

jQuery文檔處理程序介紹

在jQuery中想實現(xiàn)在DOM加載完畢后的處理邏輯,只需要使用$(document).ready()事件。此事件函數(shù)稱為"jQuery文檔處理程序"。

可以在頁面的任何位置,甚至是外部的js文件中,編寫如下列語句:

$(document).ready(function (){ alert("document.ready")});

則在頁面的DOM加載完畢后,會立刻執(zhí)行alert語句。如果頁面上有大的圖片、js文件等外部資源需要加載,jQuery的文檔處理程序會在其之前執(zhí)行,而window.onload和boyd.onload是在所有的資源文件加載完畢后執(zhí)行的。

Ready()函數(shù)時jQuery"事件函數(shù)"中提供的一個jQuery對象函數(shù),簽名位ready(fn)。

fn是ready事件發(fā)生時執(zhí)行的函數(shù)。

因為是jQuery對象函數(shù),意味著可以在任何jQuery對象上調(diào)用:

$("body").ready(function (){ alert("body.ready")});

上面的語句等同于:

$(document).ready(function (){alert("body.ready")});

雖然ready()函數(shù)可以作用在任何jQuery對象上,但是使用時一定要注意對象是否具有ready事件。

也可以使用"$(fn)"這種簡化的形式:

$(function (){….})
//等效于$(document).ready(function(){…});

同jQuery中所有的事件對象一樣,$(document).ready事件,會按照出現(xiàn)的先后順序執(zhí)行。

比如,可以調(diào)用兩次$(document).ready事件:

$(document).ready(function (){alert("document.ready-1")});
$(document). ready(function (){alert("document.ready-2")});

則在DOM加載完畢后,首先輸出"document.ready-1",然后輸出"document.ready-2"。如果使用傳統(tǒng)的:

Window.onload=function(){…..};

上面的代碼會將window.onload原有的事件處理掉,然后綁定新的事件。

jQuery文檔處理程序的優(yōu)勢

如果腳本需要在頁面加載時執(zhí)行,那么大部分的腳本都可以放在$(document).ready()事件中。

在舉例jQuery文檔處理程序的優(yōu)勢之前,先看一個常見的JavaScript編程錯誤:dom未加載完成即改變dom模型。

在傳統(tǒng)的javascript編程中。有時會在頁面的頭部或者底部直接插入script模塊并編寫代碼,比如下面的例子:

<!DOCTYPE html PUBLIC "-//W3C//DTDXHTML 1.0 
Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<htmlxmlns="http://www.w3.org/1999/xhtml">
<head>
  <title>jQueryStorm – 常見錯誤編程方式舉例</title>
  <scriptlanguage="javascript"type="text/javascript"src="../include/jquery-1.7.1.js"></script>
</head>
<body>
<!-- 頁面內(nèi)容部分 –>
<div id="divMsg" style="border:solid 1px#000000;padding:20px;"></div>
<!-- 尾部模塊 -->
<script language="javascript" type="text/javascript">
  //這條語句在某些情況下會導(dǎo)致錯誤
  Document.getElementById("divMsg").innerHTML="<divstyle=\"border:solid 2px #FF0000\">動態(tài)添加的圖層</div>";
</script>
</boyd>
</html>

此例子在所有的瀏覽器都運行良好,但是存在隱患。因為在頁面加載時,就在divMsg容器中添加了一個新的div對象,也就是添加了一個dom對象,當(dāng)網(wǎng)速變慢或者頁面很大需要一定的加載時間,會出現(xiàn)"中止操作"的錯誤。

這個錯誤甚至曾經(jīng)在Google首頁、淘寶等知名網(wǎng)站上都出現(xiàn)過,因為此錯誤很難在測試時候發(fā)現(xiàn)。

所以做web開發(fā)是要記住一條真理:永遠(yuǎn)不要再dom加載時修改dom結(jié)構(gòu)。

如果需要在頁面加載時修改dom結(jié)構(gòu),原始的做法是通過window.onload和body.onload事件實現(xiàn),比如針對上面的錯誤例子,可以修改為:

<script type="text/javascript">
Window.onload=function()
{
  Document.getElementById("divMsg").innerHTML="<divstyle="\border:solid 2px #FF0000\">動態(tài)添加的圖層</div>";
};
</script>

具體的實現(xiàn)方式還有很多,應(yīng)用window.onload和body.onload是因為這兩個事件都是在dom加載完成并且所有頁面資源加載完成后才執(zhí)行的,這是最簡單的做法。或者根據(jù)"document.readyState"判斷dom的狀態(tài),如果是"complete"則進(jìn)行某些操作,jQuery的文檔處理程序$(document).ready內(nèi)部正是使用的此原理。

更多關(guān)于jquery相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《jquery常用操作技巧匯總》、《jQuery常見事件用法與技巧總結(jié)》、《jQuery操作json數(shù)據(jù)技巧匯總》、《jQuery操作xml技巧總結(jié)》及《jQuery擴展技巧總結(jié)

希望本文所述對大家jquery程序設(shè)計有所幫助。

相關(guān)文章

  • jquery庫或JS文件在eclipse下報錯問題解決方法

    jquery庫或JS文件在eclipse下報錯問題解決方法

    在工程中導(dǎo)入jquery-1.7.1之后一直有一個紅叉叉,雖然不會影響程序功能,但是看著非常不舒服,下面有個不錯的解決方法,大家可以嘗試下
    2014-04-04
  • jQuery插件zoom實現(xiàn)圖片全屏放大彈出層特效

    jQuery插件zoom實現(xiàn)圖片全屏放大彈出層特效

    jQuery zoom是一款能夠查看相冊大圖的jQuery彈出層插件,點擊相冊的縮略圖,就會彈出該相片對應(yīng)的大圖,并且?guī)в袀€性的加載動畫,還有上一張下一張按鈕以及關(guān)閉按鈕。使用方法非常簡單。兼容IE8、360、FireFox、Chrome、Safari、Opera、傲游、搜狗、世界之窗等瀏覽器。
    2015-04-04
  • jQuery實現(xiàn)的鼠標(biāo)滾輪控制圖片縮放功能實例

    jQuery實現(xiàn)的鼠標(biāo)滾輪控制圖片縮放功能實例

    這篇文章主要介紹了jQuery實現(xiàn)的鼠標(biāo)滾輪控制圖片縮放功能,結(jié)合完整實例形式分析了jQuery基于鼠標(biāo)滾輪mousewheel事件進(jìn)行頁面元素屬性動態(tài)操作的相關(guān)實現(xiàn)技巧,需要的朋友可以參考下
    2017-10-10
  • 最新評論