jQuery的文檔處理程序詳解
來源:易賢網(wǎng) 閱讀:771 次 日期:2016-07-01 15:30:58
溫馨提示:易賢網(wǎng)小編為您整理了“jQuery的文檔處理程序詳解”,方便廣大網(wǎng)友查閱!

這篇文章主要介紹了jQuery的文檔處理程序,結(jié)合實(shí)例形式詳細(xì)分析了jQuery文檔處理程序的概念、原理、使用方法與相關(guān)注意事項(xiàng),并詳細(xì)講述了文檔處理程序的優(yōu)勢(shì),需要的朋友可以參考下

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

jQuery文檔處理程序

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

jQuery文檔處理程序介紹

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

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

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

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

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

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

因?yàn)槭莏Query對(duì)象函數(shù),意味著可以在任何jQuery對(duì)象上調(diào)用:

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

上面的語句等同于:

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

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

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

$(function (){….})

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

同jQuery中所有的事件對(duì)象一樣,$(document).ready事件,會(huì)按照出現(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(){…..};

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

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

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

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

在傳統(tǒng)的javascript編程中。有時(shí)會(huì)在頁面的頭部或者底部直接插入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 – 常見錯(cuò)誤編程方式舉例</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">

  //這條語句在某些情況下會(huì)導(dǎo)致錯(cuò)誤

  Document.getElementById("divMsg").innerHTML="<divstyle=\"border:solid 2px #FF0000\">動(dòng)態(tài)添加的圖層</div>";

</script>

</boyd>

</html>

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

這個(gè)錯(cuò)誤甚至曾經(jīng)在Google首頁、淘寶等知名網(wǎng)站上都出現(xiàn)過,因?yàn)榇隋e(cuò)誤很難在測試時(shí)候發(fā)現(xiàn)。

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

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

<script type="text/javascript">

Window.onload=function()

{

  Document.getElementById("divMsg").innerHTML="<divstyle="\border:solid 2px #FF0000\">動(dòng)態(tài)添加的圖層</div>";

};

</script>

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

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

更多信息請(qǐng)查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機(jī)網(wǎng)站地址:jQuery的文檔處理程序詳解
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2025國考·省考課程試聽報(bào)名

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