在頁(yè)面加載結(jié)束后,瀏覽器會(huì)通過js為dom元素添加事件。原生的js中使用 window.onload 方法;在JQ中使用$(document).ready()。這個(gè)方法在dom載入就緒時(shí)對(duì)其進(jìn)行操縱并調(diào)用執(zhí)行它所綁定的函數(shù)。
高青網(wǎng)站建設(shè)公司成都創(chuàng)新互聯(lián)公司,高青網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為高青超過千家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\外貿(mào)網(wǎng)站制作要多少錢,請(qǐng)找那個(gè)售后服務(wù)好的高青做網(wǎng)站的公司定做!
那么它和window.onload有何不同呢?
window.onload是在網(wǎng)頁(yè)中所有元素 加上所有資源 ++完全加++載到瀏覽器后才執(zhí)行。
而$(document).ready()中綁定的事件是在 dom完全就緒 時(shí)就可以被調(diào)用,此時(shí)對(duì)于jQuery來說都是可以被訪問的(關(guān)聯(lián)的資源可能并沒有被加載完畢)。
舉個(gè)例子來說,在$(document).ready()中定義了圖片的寬高,但由于此時(shí)圖片還沒有被加載完畢,此時(shí)的寬高不會(huì)生效。要解決這個(gè)問題可以使用jQuery中的 load ()方法。
load()方法會(huì)在元素的onload事件中綁定一個(gè)處理函數(shù),如果該處理函數(shù)綁定給window對(duì)象,則會(huì)在所有資源加載完畢后觸發(fā),如果load綁定在元素上則會(huì)在該元素加載完畢后觸發(fā)。
既然window.onload比較完備為什么還要用jQuery中的$(document).ready()呢?
window.onload事件 每次只能保存對(duì)一個(gè)函數(shù)的引用 ,他會(huì)覆蓋掉之前的函數(shù),所以不能再現(xiàn)有行為上添加新的行為。如果引用了多個(gè)js文件,每個(gè)都需要window.onload方法就導(dǎo)致編碼復(fù)雜。
使用$(document).ready()方法能夠很好地解決這種問題,每次調(diào)用$document.ready()方法都會(huì)在現(xiàn)有行為上追加新的行為,這些行為會(huì)根據(jù)注冊(cè)順序依次執(zhí)行。
需要準(zhǔn)備的材料分別有:電腦、html編輯器、chrome瀏覽器。
1、首先,打開html編輯器,新建html文件,例如:index.html,并引入jquery。
2、在index.html中的script標(biāo)簽,輸入jquery代碼:
$('div').load(function () {$('body').append('div has load');});
3、瀏覽器運(yùn)行index.html頁(yè)面,此時(shí)頁(yè)面中div加載完會(huì)調(diào)用事件輸出“div has load”。
1:表現(xiàn)形式:
傳統(tǒng)的:
javascript的加載事件:
body onload = “函數(shù)()”
window.onload= function(){}
jquery :
① $(document).ready(function處理);
② $().ready(function處理);
③ $(function處理); 對(duì)第一種加載的封裝而已
2:設(shè)置個(gè)數(shù):
在同一個(gè)請(qǐng)求里邊,jquery的可以設(shè)置多個(gè),而傳統(tǒng)方式只能設(shè)置一個(gè)
傳統(tǒng)方式加載事件是給onload事件屬性賦值,多次賦值,后者會(huì)覆蓋前者。
jquery方式加載事件是把每個(gè)加載事件都存入一個(gè)數(shù)組里邊,成為數(shù)組的元素,執(zhí)行的時(shí)候就遍歷該數(shù)組執(zhí)行每個(gè)元素即可,因此其可以設(shè)置多個(gè)加載事件。:
3:執(zhí)行時(shí)機(jī):
傳統(tǒng)方式加載事件,是全部?jī)?nèi)容(文字、圖片、樣式)在瀏覽器顯示完畢再給執(zhí)行加載事件。
jquery方式加載事件,只要全部?jī)?nèi)容(文字、圖片、樣式)在內(nèi)存里邊對(duì)應(yīng)的DOM樹結(jié)構(gòu)繪制完畢就給執(zhí)行,有可能對(duì)應(yīng)的內(nèi)容在瀏覽器里邊還沒有顯示。
如果綁定給window對(duì)象,則會(huì)在所有內(nèi)容加載后觸發(fā),包括窗口,框架,對(duì)象和圖像。如果綁定在元素上,則當(dāng)元素的內(nèi)容加載完畢后觸發(fā)。
注意:只有當(dāng)在這個(gè)元素完全加載完之前綁定load的處理函數(shù),才會(huì)在他加載完后觸發(fā)。如果之后再綁定就永遠(yuǎn)不會(huì)觸發(fā)了。所以不要在$(document).ready()里綁定load事件,因?yàn)閖Query會(huì)在所有DOM加載完成后再綁定load事件。因此,使用load方法時(shí)盡量把load方法寫在頁(yè)面頂部。
調(diào)用load方法的完整格式是:load(
url,
[data],
[callback]
),
其中:
?url:是指要導(dǎo)入文件的地址。
?data:可選參數(shù);因?yàn)長(zhǎng)oad不僅僅可以導(dǎo)入靜態(tài)的html文件,還可以導(dǎo)入動(dòng)態(tài)腳本,例如PHP文件,所以要導(dǎo)入的是動(dòng)態(tài)文件時(shí),我們可以把要傳遞的參數(shù)放在這里。
?callback:可選參數(shù);是指調(diào)用load方法并得到服務(wù)器響應(yīng)后,再執(zhí)行的另外一個(gè)函數(shù)。
一:如何使用data
1.加載一個(gè)php文件,該php文件不含傳遞參數(shù)$("#myID").load("test.php");
//在id為#myID的元素里導(dǎo)入test.php運(yùn)行后的結(jié)果2.
加載一個(gè)php文件,該php文件含有一個(gè)傳遞參數(shù)
$("#myID").load("test.php",{"name"
:
"Adam"});
//導(dǎo)入的php文件含有一個(gè)傳遞參數(shù),類似于:test.php?name=Adam3.
加載一個(gè)php文件,該php文件含有多個(gè)傳遞參數(shù)。注:參數(shù)間用逗號(hào)分隔
$("#myID").load("test.php",{"name"
:
"Adam"
,"site":"61dh.com"});
//導(dǎo)入的php文件含有一個(gè)傳遞參數(shù),類似于:test.php?name=Adamsite=61dh.com4.
加載一個(gè)php文件,該php文件以數(shù)組作為傳遞參數(shù)
$("#myID").load("test.php",{'myinfo[]',
["Adam",
"61dh.com"]});
//導(dǎo)入的php文件含有一個(gè)數(shù)組傳遞參數(shù)。注意:使用load,這些參數(shù)是以POST的方式傳遞的,因此在test.php里,不能用GET來獲取參數(shù)。
二:如何使用callback
比如我們要在load方法得到服務(wù)器響應(yīng)后,慢慢地顯示加載的內(nèi)容,就可以使用callback函數(shù)。代碼如下:
復(fù)制代碼
代碼如下:
$("#go").click(function(){
$("#myID").load("welcome.php",
{"lname"
:
"Cai",
"fname"
:
"Adam",
function(){
$("#myID").fadeIn('slow');}
);
});
備注:
在load的url里加上空格后面就可以跟選擇器了。
例如:
復(fù)制代碼
代碼如下:
$("body").load("test.html
#a");