|
document.onreadystatechange=function() { if(document.readyState == 'complete'){ showDialog('來自網(wǎng)頁(yè)的消息','用戶名或密碼錯(cuò)誤,請(qǐng)重新輸入!','warning'); } };
問題解決,一切OK!
復(fù)制代碼 代碼如下:
document.onreadystatechange = subSomething;//當(dāng)頁(yè)面加載狀態(tài)改變的時(shí)候執(zhí)行這個(gè)方法.
function subSomething()
{
if(document.readyState == "complete"){ //當(dāng)頁(yè)面加載狀態(tài)為完全結(jié)束時(shí)進(jìn)入
//你要做的操作。
}
}
說明 :onreadystatechange 事件能辨識(shí)readyState 屬性的改變。
關(guān)于onreadystatechange屬性的一點(diǎn)疑問
在編寫Ajax方法的時(shí)候,我們經(jīng)常會(huì)寫上類似于這樣的代碼:
復(fù)制代碼 代碼如下:
<script type="text/Javascript">
var xmlHttp;
//創(chuàng)建一個(gè)XmlHttpRequeset對(duì)象
function createXMLHttpRequest()...{
if(window.ActiveXObject)...{
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}
else if(window.XMLHttpRequest)...{
xmlHttp = new XMLHttpRequest();
}
}
//開始一個(gè)請(qǐng)求
function startRequest()...{
createXMLHttpRequest();
xmlHttp.onreadystatechange = handlestatechange;
xmlHttp.open("GET", "SimpleRespose.xml", true);
xmlHttp.Send(null);
}
function handlestatechange()...{
if(xmlHttp.readyState == 4)...{//描述一種"已加載"狀態(tài);此時(shí),響應(yīng)已經(jīng)被完全接收。
if(xmlHttp.status == 200)...{//200表示成功收到
alert("The Server Replied with:" + xmlHttp.responseText)
}
}
}
</script>
第一次閱讀這段代碼的時(shí)候,我就感到了一點(diǎn)點(diǎn)不對(duì)勁,但是說不出來什么地方不對(duì)勁。隨著對(duì)Ajax代碼的進(jìn)一步了解,這種感覺時(shí)刻伴隨著我。
后來,我知道了這種感覺來自于什么地方。
看看startRequest函數(shù)。我們發(fā)現(xiàn)xmlHttp.onreadystatechange指向了一個(gè)函數(shù),這個(gè)函數(shù)是在xmlHttpRequest.readyState發(fā)生改變的時(shí)候觸發(fā)。我們?cè)賮砜磗tartRequest函數(shù),想象一下整個(gè)請(qǐng)求發(fā)送的步驟。現(xiàn)在我們點(diǎn)擊一個(gè)按鈕,觸發(fā)了一個(gè)startRequest函數(shù)。函數(shù)往下走,第一步是createXmlHttpRequest(),它的作用是創(chuàng)建一個(gè)xmlHttpRequest對(duì)象,當(dāng)它完畢的時(shí)候,xmlHttpRequest.readyState的值是0(window.alert跟蹤得到的),程序繼續(xù)往下走,xmlHttp.onreadystatechange = handlestatechange,因?yàn)闋顟B(tài)沒有改變(xmlHttpRequest.readyState的值是0),所以不觸發(fā)函數(shù),緊接著是Open()和Send(),那么,整個(gè)函數(shù)從頭到尾都應(yīng)該沒有觸發(fā)handlestatechange函數(shù)啊,但是為什么出來的結(jié)果是正確的呢?
后來我用window.alert跟蹤xmlHttp.readystate的變化,發(fā)現(xiàn)于原來它運(yùn)行的機(jī)制是這樣的。首先創(chuàng)建一個(gè)xmlHttpRequest的對(duì)象之后xmlHttp.readyState的值是0了,然后xmlHttp.onreadystatechange = handlestatechange沒有運(yùn)行。緊接著是open(),這個(gè)函數(shù)發(fā)生了之后xmlHttp.readyState的值是1了,那么就會(huì)有一個(gè)斷點(diǎn)在Open()函數(shù)處斷開,保留現(xiàn)場(chǎng),緊接著又返回到xmlHttp.onreadystatechange = handlestatechange運(yùn)行,然后再執(zhí)行Send()函數(shù),這個(gè)函數(shù)發(fā)生了之后xmlHttp.readyState的值是2了,接著又返回到xmlHttp.onreadystatechange = handlestatechange運(yùn)行。以此類推。
瀏覽器因?yàn)椴荒苷嬲叵衩嫦驅(qū)ο竽敲淳幊蹋哉伊藗€(gè)折衷的辦法,但是這個(gè)辦法看起來不倫不類,想了半天,再跟一個(gè)同學(xué)一起討論,才得出這樣的一個(gè)結(jié)果。
JavaScript技術(shù):document.onreadystatechange事件的用法分析,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。