我们在自己实现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是回调函数
}