XMLHttp连续调用SEND需要注意的问题

我们在自己实现AJAX的时候,在应用中常需要连续调用SEND函数,并寄希望SEND函数调用结束后可以自动正确调用其回调函数,然而有时候不注意可能事与愿违,产生此情况的原因在于AJAX的实现上存在不正确用法。

如我们写调用方法代码如下:

var xmlhttp=new XMLHttpRequest(); //此处没有考虑不同浏览器兼容问题

function send (....) { //

xmlhttp.open(post,url,true); //url为调用的网络服务页面或服务

xmlhttp.send xml;

xmlHttp.onreadystatechange=callbackfunc; //callbackfunc是回调函数

}

这样如果连续两次包括两次以上连续调用send函数(代码见下)将会发现只有最后一次调用的回调函数被执行,而之前的回调函数根本不会被调用

send(.....); //第一次调用;

send(.....); //第二次调用;这样只有此处的回调函数会被调用;

其实产生这个情况的主要原因在于,每个xmlhttp对象的一此send只能对应相应一个onreadystatechange事件,这样当第一次调用后,立即发出第二次调用,则onreadystatechange会反映第二次调用的状况,因此如果有需求需要连续两次或者两次以上调用Send函数,则必须每次使用不同的xmlhttp对象 ,写法可以参考如下:

function send (....) { //

var xmlhttp=new XMLHttpRequest(); //此处没有考虑不同浏览器兼容问题,

//此处xmlhttp与上面写法不同是函数内部的局部变量

xmlhttp.open(post,url,true); //url为调用的网络服务页面或服务

xmlhttp.send xml;

xmlHttp.onreadystatechange=callbackfunc; //callbackfunc是回调函数

}

posted @ 2009-12-19 18:29  dzqabc  阅读(1105)  评论(0编辑  收藏  举报