灵活运用ajax的方法beforeSend改善用户体验

我们知道,开源框架jquery的API—— jquery.ajax中有一个方法beforeSend,用于在向服务器发送请求前添加一些处理函数。这是一个ajax事件,在ajax请求开始之前就被触发,通常允许用户修改XMLHttpRequest对象(比如说设置附加的头部信息),关于ajax事件的解释可参考文档:http://docs.jquery.com/Ajax_Events


 
这里我们讨论的,是如何改善Web应用程序交互体验的问题。通常由于网络等客观因素导致当浏览器向服务器发送请求的时候,服务器并没有立刻做出响应,需要等待若干毫秒甚至数秒的时间。而很多互联网用户并不知道这种存在这种现象,他们当中有的误认为是自己没有操作成功(比如按钮没有点击上),从而会重复刚才的操作数次,如果没有对网页前端代码做相应的处理,通常会导致这种相同的请求被重复提交多次。要避免这种现象的发生,我们通常会在代码中增加对beforeSend事件的处理,比方说在用户点击按钮后立刻给出一个诸如“请求发送中,请稍候”的 提示。



往往我们还见到一种情况,很多网站在加载内容的过程中给出“数据加载中,请稍候”的提示,当内容被加载完毕后显示内容。很显然这样的需求也可以通过对beforeSend事件处理来满足,但是笔者不推荐这种处理方法,那么稍微优化一些的方法是什么呢?请往下看。


 
假定我们要显示内容的HTML标签为<p id="content"></p>,我们可以设置标签的默认文本为加载中的提示。示例代码如下:


<p id="content">数据加载中,请稍候</p>  


当内容加载完毕时,我们可以通过ID选择器,将该标签中的文本替换成最终的内容。以此来取代beforeSend,效率更高。


 
总结一下,什么时候用beforeSend,什么时候用文本替换,取决于ajax请求前后你所展示的DOM元素是否一致,如果你所展示的DOM元素在请求之前已经存在,那么通过上述文本替换的方式来处理会好些,如果除此以外你还需增加其他的需求,那么还是用beforeSend来处理吧。


 


问题虽然很简单,但是如果能深入考虑一下,得到的解法可能不同。笔者旨在抛砖引玉,希望对一些细小的需求也能做到深入分析,持续优化,改进你的代码。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值