<script type="text/javascript">
var xmlHttp;
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", "simpleResponse.xml", true);
xmlHttp.send(null);
}
function handleStateChange() {
if(xmlHttp.readyState == 4) {
if(xmlHttp.status == 200) {
alert("The server replied with: " + xmlHttp.responseText);
}
}
}
</script>
//////////////////////////////////
我的問題是:
xmlHttp.onreadystatechange = handleStateChange;這句話中
是不是表示 調用handleStateChange方法 來返回一個狀態給xmlHttp.onreadystatechange
我覺得是這樣的 沒錯吧?
有了狀態以後就能執行下面的open() send()嗎?
還有 最不明白的就是 既然是執行handleStateChange方法
為什麼
不寫handleStateChange();要寫handleStateChange;
還有第三個問題
既然 要返回給xmlHttp.onreadystatechange
為什麼 handleStateChange()方法裡沒有return? 那他知道返回什麼嗎?
答案:
Question1:handleStateChange這個是回呼函數,因為ajax是非同步方式,那麼這種非阻塞的運行機制必然要求有一個回呼函數提 供給服務端來調用,也就是說,你通過url發送請求到服務端之後,服務端再處理完資料後,會調用你提供給它的回呼函數,將資料返回給你,所以,這個方法不 是給你來調用的,是給服務端調用的
Q2:為什麼寫handleStateChange而不是handleStateChange()呢,這個是個簡單的嘗試,我們需要的只是申明 函數的入口,而不是調用該函數,簡單理解,handleStateChange就是指handleStateChange()這個函數的地址
Q3:見Q1,既然是回呼函數,服務端已經完成工作,剩下的就是你函數自己的事情了,自然不需要什麼return了,你只需要在 handleStateChange這個函數中接收服務端傳回的資料做自己的業務處理就可以了,到這步,你已經完成了與服務端的通訊了,無需return