Ajax一些问题的解决方案

坚持每天写博文,记录开发中的点点滴滴

  • ajax的请求都不需要使用缓存.

浏览器实现缓存原理:第二次请求的url如果和第一次请求的url一样,那么浏览器会使用缓存.
解决办法:让每次请求的url不一样.
_t参数没有任何意义,目的是让url不同解决浏览器缓存问题.
“/AjaxServlet?_t=”+new Date().getTime()

  • 出错的时候限制
    当请求出错的时候,比如我在后台写一行错误代码:
int i = 1/0;

那我的请求结果为:
这里写图片描述

但是这个结果不能让用户看到,那我应该在JS中添加一个判断:

if(ajax.readyState == 4 && ajax.status == 200){
                //后台文本数据
                var text = ajax.responseText;
                document.getElementById("text").innerHTML=text;
            }

其中readyState是请求状态 ,而status http的响应状态,正常是200

如果我想打印个错误信息:

if(ajax.readyState == 4){
                if(ajax.status == 200){
                    //后台文本数据
                    var text = ajax.responseText;
                    document.getElementById("text").innerHTML=text;
                }else{
                    alert("请求失败");
                }
            }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值