我们知道,开源框架jquery的API—— jquery.ajax中有一个方法beforeSend,用于在向服务器发送请求前添加一些处理函数。这是一个ajax事件,在ajax请求开始之前就被触发,通常允许用户修改XMLHttpRequest对象(比如说设置附加的头部信息),关于ajax事件的解释可参考文档:http://docs.jquery.com/Ajax_Events
这里我们讨论的,是如何改善Web应用程序交互体验的问题。通常由于网络等客观因素导致当浏览器向服务器发送请求的时候,服务器并没有立刻做出响应,需要等待若干毫秒甚至数秒的时间。而很多互联网用户并不知道这种存在这种现象,他们当中有的误认为是自己没有操作成功(比如按钮没有点击上),从而会重复刚才的操作数次,如果没有对网页前端代码做相应的处理,通常会导致这种相同的请求被重复提交多次。要避免这种现象的发生,我们通常会在代码中增加对beforeSend事件的处理,比方说在用户点击按钮后立刻给出一个诸如“请求发送中,请稍候”的 提示。
往往我们还见到一种情况,很多网站在加载内容的过程中给出“数据加载中,请稍候”的提示,当内容被加载完毕后显示内容。很显然这样的需求也可以通过对beforeSend事件处理来满足,但是笔者不推荐这种处理方法,那么稍微优化一些的方法是什么呢?请往下看。
假定我们要显示内容的HTML标签为<p id="content"></p>,我们可以设置标签的默认文本为加载中的提示。示例代码如下:
当内容加载完毕时,我们可以通过ID选择器,将该标签中的文本替换成最终的内容。以此来取代beforeSend,效率更高。
总结一下,什么时候用beforeSend,什么时候用文本替换,取决于ajax请求前后你所展示的DOM元素是否一致,如果你所展示的DOM元素在请求之前已经存在,那么通过上述文本替换的方式来处理会好些,如果除此以外你还需增加其他的需求,那么还是用beforeSend来处理吧。
问题虽然很简单,但是如果能深入考虑一下,得到的解法可能不同。笔者旨在抛砖引玉,希望对一些细小的需求也能做到深入分析,持续优化,改进你的代码。