DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> AJAX入門 >> AJAX基礎知識 >> ajax 同步和異步XMLHTTP代碼分析
ajax 同步和異步XMLHTTP代碼分析
編輯:AJAX基礎知識     
在網頁腳本編程中,絕大多數情況應該使用異步模式;同步模式將會掛起當前的腳本引擎,所以當你使用同步模式時,你應該明白自己要什麼。而在C++開發中,同步模式應該是主流,如果一定要使用異步模式加回調,可以參考Using IXMLHTTPRequest onreadystatechange from C++一文。

下面是采用異步模式獲取遠程主機上RSS文件的代碼,關鍵的地方是設置一個回調函數給IXMLHTTPRequest::onreadystatechange。為了防止腳本過早退到控制台,使用了asyncDone變量檢測當前狀態。當然,如果在網頁中使用XMLHTTP,則不用這麼麻煩——只要IE網頁不關閉,回調函數不會退出。
復制代碼 代碼如下:
var xmlhttp = new ActiveXObject("MSXML2.XMLHTTP.6.0");
var url = "http://www.jb51.net/rss.xml";

var asyncDone = false;

try {
xmlhttp.open("GET", url, true);
xmlhttp.onreadystatechange = onReadyStateChange;
xmlhttp.send(null);

// loop so that the program from quiting
while (!asyncDone) {
WScript.Sleep(100);
}

WScript.Echo(xmlhttp.responseText);
} catch (e) {
WScript.Echo(e);
}

function onReadyStateChange() {
WScript.Echo("readyState: " + xmlhttp.readyState);
if (xmlhttp.readyState == 4) {
asyncDone = true;
}
}

同步模式獲取遠程主機資源的代碼要簡單許多:

復制代碼 代碼如下:
var xmlhttp = new ActiveXObject("MSXML2.XMLHTTP.6.0");
var url = "http://www.jb51.net/rss.xml";

try {
xmlhttp.open("GET", url, false);
xmlhttp.send(null);
WScript.Echo(xmlhttp.responseText);
} catch (e) {
WScript.Echo(e);
}

不過,如果在IE中使用同步模式,由於沒有了回調的機制而且IE又不支持腳本開線程,腳本會被掛起直到XMLHTTP返回。注意,IE界面本身會被掛起。

同步還是異步,具體問題還要具體分析。
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved