ajax 同步和异步XMLHTTP代码分析
2009-11-26 00:00
501 查看
在网页脚本编程中,绝大多数情况应该使用异步模式;同步模式将会挂起当前的脚本引擎,所以当你使用同步模式时,你应该明白自己要什么。而在C++开发中,同步模式应该是主流,如果一定要使用异步模式加回调,可以参考Using IXMLHTTPRequest onreadystatechange from C++一文。
下面是采用异步模式获取远程主机上RSS文件的代码,关键的地方是设置一个回调函数给IXMLHTTPRequest::onreadystatechange。为了防止脚本过早退到控制台,使用了asyncDone变量检测当前状态。当然,如果在网页中使用XMLHTTP,则不用这么麻烦――只要IE网页不关闭,回调函数不会退出。
同步模式获取远程主机资源的代码要简单许多:
不过,如果在IE中使用同步模式,由于没有了回调的机制而且IE又不支持脚本开线程,脚本会被挂起直到XMLHTTP返回。注意,IE界面本身会被挂起。
同步还是异步,具体问题还要具体分析。
下面是采用异步模式获取远程主机上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界面本身会被挂起。
同步还是异步,具体问题还要具体分析。
相关文章推荐
- ajax 同步和异步XMLHTTP代码分析
- ajax 同步请求和异步请求的差异分析
- 图片上传,支持同步/异步、预览(MVC、uploadify异步提交、js预览、ajaxSubmit异步提交)兼容大部分浏览器,含代码
- 同步和异步XMLHTTP代码
- 使用php方法curl抓取AJAX异步内容思路分析及代码分享
- AJAXPro用法,关于JS同步和异步调用后台代码的学习
- ajax 同步请求和异步请求的差异分析
- Ajax同步与异步传输的示例代码
- 使用php方法curl抓取AJAX异步内容思路分析及代码分享
- Ajax同步与异步传输的示例代码
- ajax 操作/同步、异步区别
- C#完整的通信代码(点对点,点对多,同步,异步,UDP,TCP),多多宜善
- java 同步、异步、阻塞和非阻塞分析
- Java同步代码转异步代码
- ajax ,async: false, 同步和异步的参数
- Generator:同步代码书写异步情怀
- jquery的ajax同步和异步
- C#完整的通信代码(点对点,点对多,同步,异步,UDP,TCP)
- ajax中的async属性值之同步和异步及同步和异步区别