枫林在线论坛精华区>>技术交流 |
[382553] 主题: Ajax铺设了更好的开发Web应用的道路(2) |
作者: leaflet (Leaflet) | ||
标题: Ajax铺设了更好的开发Web应用的道路(2)[转载] | ||
来自: 192.168.*.* | ||
发贴时间: 2005年12月17日 11:13:06 | ||
长度: 2068字 | ||
http://searchwebservices.techtarget.com.cn/tips/212/2179212_1.sh tml Ajax铺设了更好的开发Web应用的道路 【2005-11-03 11:17】【】【赛迪网】 发送一个XMLHttpRequest 我将从Ajax时序图的起点开始:从浏览器创建并发送一个XMLHttpRequ est。不幸的是 ,在不同的浏览器中创建XMLHttpRequest的方法都不一样。列表2中示例的 JavaScript函 数消除了这些与浏览器种类相关的问题,正确检测与当前浏览器相关的方 法,并返回一 个可以使用的XMLHttpRequest。最好将它看成备用代码,将它简单拷贝到 你的JavaScrip t库中,在需要一个XMLHttpRequest时使用它即可。 列表2:跨浏览器创建一个XMLHttpRequest /* * 返回一个新建的XMLHttpRequest对象, 若浏览器不支持则失败 */ function newXMLHttpRequest() { var xmlreq = false; if (window.XMLHttpRequest) { // 在非Microsoft浏览器中 创建XMLHttpRequest对象 xmlreq = new XMLHttpRequest(); } else if (window.ActiveXObject) { //通过MS ActiveX创建XMLHttpRequest try { // 尝试按新版InternetExplorer方法创建 xmlreq = new ActiveXObject ("Msxml2.XMLHTTP"); } catch (e1) { // 创建请求的ActiveX对象失败 try { // 尝试按老版InternetExplorer方法创建 xmlreq = new ActiveXObject ("Microsoft.XMLHTTP"); } catch (e2) { // 不能通过ActiveX创建XMLHttpRequest } } } return xmlreq; } 稍后,我将讨论如何对待不支持XMLHttpReauest的浏览器的一些技巧 。现在,列表2 中展示的示例函数将总是可以返回一个XMLHttpReauest实例。 回到购物车例子的场景中,只要用户针对某一个目录条目点击了Add to Cart按钮, 我就要调用一个Ajax交互。名为addToCart()的onclick函数通过Ajax调用 (如列表1中所 示)来负责更新购物车的状态。 在列表3中,addToCart()要做的第一件事就是通过调用newXMLHttpRe auest函数(如 列表2中所示)来获取一个XMLHttpRequest的实例,并且注册一个回调函数 来接受服务器 响应(我将在稍后详细解释,请参见列表6)。 因为,此请求将会修改服务器状态,我将使用一个HTTP POST来处理它 。通过POST传 送数据需要三个步骤:首先,我需要打开一个到进行通讯的服务器资源的P OST连接—在现 在例子中是一个URL映射为cart.do的服务器端servlet。 |
||
========== * * * * * ==========
|
返回 |