天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

document.onreadystatechange事件的用法分析

這兩天,正在給部門的一個項目做優化,其中一項是將web應用中的所有alert用div方式實現,Javascript的相關方法都寫好了,方法名為showDialog,前臺頁面調用showDialog方法一點也沒有問題,可是頁面一旦提交,從后臺輸出腳本,調用showDialog方法,就會時不時的出現問題了,報一個無法打開InterNET站點的錯誤,在腳本中下斷點調試,依然找不到問題的根源,最后到網上一查,這個問題有可能是頁面沒有完全加載造成的,于是乎,修改后臺輸出腳本的代碼,將其改為
document.onreadystatechange=function() { if(document.readyState == 'complete'){ showDialog('來自網頁的消息','用戶名或密碼錯誤,請重新輸入!','warning'); } };
問題解決,一切OK!
復制代碼 代碼如下:
document.onreadystatechange = subSomething;//當頁面加載狀態改變的時候執行這個方法.
function subSomething()
{
if(document.readyState == "complete"){ //當頁面加載狀態為完全結束時進入
//你要做的操作。
}
}

說明 :onreadystatechange 事件能辨識readyState 屬性的改變。

關于onreadystatechange屬性的一點疑問
在編寫Ajax方法的時候,我們經常會寫上類似于這樣的代碼:
復制代碼 代碼如下:
<script type="text/Javascript">
var xmlHttp;
//創建一個XmlHttpRequeset對象
function createXMLHttpRequest()...{
if(window.ActiveXObject)...{
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}
else if(window.XMLHttpRequest)...{
xmlHttp = new XMLHttpRequest();
}
}
//開始一個請求
function startRequest()...{

createXMLHttpRequest();
xmlHttp.onreadystatechange = handlestatechange;
xmlHttp.open("GET", "SimpleRespose.xml", true);
xmlHttp.Send(null);
}

function handlestatechange()...{
if(xmlHttp.readyState == 4)...{//描述一種"已加載"狀態;此時,響應已經被完全接收。
if(xmlHttp.status == 200)...{//200表示成功收到
alert("The Server Replied with:" + xmlHttp.responseText)
}
}
}
</script>

第一次閱讀這段代碼的時候,我就感到了一點點不對勁,但是說不出來什么地方不對勁。隨著對Ajax代碼的進一步了解,這種感覺時刻伴隨著我。

后來,我知道了這種感覺來自于什么地方。

看看startRequest函數。我們發現xmlHttp.onreadystatechange指向了一個函數,這個函數是在xmlHttpRequest.readyState發生改變的時候觸發。我們再來看startRequest函數,想象一下整個請求發送的步驟。現在我們點擊一個按鈕,觸發了一個startRequest函數。函數往下走,第一步是createXmlHttpRequest(),它的作用是創建一個xmlHttpRequest對象,當它完畢的時候,xmlHttpRequest.readyState的值是0(window.alert跟蹤得到的),程序繼續往下走,xmlHttp.onreadystatechange = handlestatechange,因為狀態沒有改變(xmlHttpRequest.readyState的值是0),所以不觸發函數,緊接著是Open()和Send(),那么,整個函數從頭到尾都應該沒有觸發handlestatechange函數啊,但是為什么出來的結果是正確的呢?

后來我用window.alert跟蹤xmlHttp.readystate的變化,發現于原來它運行的機制是這樣的。首先創建一個xmlHttpRequest的對象之后xmlHttp.readyState的值是0了,然后xmlHttp.onreadystatechange = handlestatechange沒有運行。緊接著是open(),這個函數發生了之后xmlHttp.readyState的值是1了,那么就會有一個斷點在Open()函數處斷開,保留現場,緊接著又返回到xmlHttp.onreadystatechange = handlestatechange運行,然后再執行Send()函數,這個函數發生了之后xmlHttp.readyState的值是2了,接著又返回到xmlHttp.onreadystatechange = handlestatechange運行。以此類推。

瀏覽器因為不能真正地像面向對象那么編程,所以找了個折衷的辦法,但是這個辦法看起來不倫不類,想了半天,再跟一個同學一起討論,才得出這樣的一個結果。

JavaScript技術document.onreadystatechange事件的用法分析,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 日本午夜视频在线 | 精品国产自在天天线2019 | 久久精品视频在线直播6 | 成人综合在线视频免费观看完整版 | 老太脱裤子让老头玩xxxxx | 国产精品成人观看视频免费 | 成人精品视频在线观看播放 | 无码中文字幕av免费放 | 婚后被调教当众高潮H喷水 回复术士勇者免费观看全集 | 做你的爱人BD日本 | 永久免费看A片无码网站四虎 | 嫩草伊人久久精品少妇AV网站 | 欧美黑人巨大videos免费 | 亚洲 在线 日韩 欧美 | 啊灬啊别停灬用力啊在线观看视频 | 亚洲国产精品一区二区第一页 | 国产性色AV内射白浆肛交后入 | 国产欧美一区二区精品仙草咪 | 久久久免费观成人影院 | 国产午夜精品久久久久婷婷 | 桃色窝| 在线涩涩免费观看国产精品 | 激情床戏视频片段有叫声 | 亚洲欧美人成视频在线 | 乌克兰黄色录像 | 国产99久久亚洲综合精品西瓜tv | 亚洲精品天堂在线 | 青柠在线观看视频在线高清完整 | 久久高清免费视频 | 韩国无遮羞禁动漫在线观看96 | 好紧好湿太硬了我太爽了文字 | www精品一区二区三区四区 | 欧美午夜免费观看福利片 | 亚洲国产欧美国产综合在线 | 色鲁97精品国产亚洲AV高 | 天龙八部慕容属性加点 | 亚洲国产在线精品第二剧情不卡 | 污污又黄又爽免费的网站 | 国产一级毛片在线 | 久久深夜视频 | 久久国产一区二区三区 |