原生态Ajax异步请求

 

文章目录


一、.添加js文件

<input id="unameTxt" type="text" placeholder="请输入用户名"  name="uname" onblur="ckUname(this.value)"/>
添加onblur="ckUname(this.value)并传参数

二、在js文件中创建XMLHttpRequest文件

var xmlHttpRequest;//创建xmlHttpRequest
//套路写法
function createXMLHttpRequest() {
    if (window.XMLHttpRequest) {
        //符合DOM2标准的浏览器xmlHttpRequst的创建方式
        xmlHttpRequest = new XMLHttpRequest();
    } else if (window.ActiveXObject) {//表示IE浏览器
        try {
            xmlHttpRequest = new ActiveXObject("Microsoft.XMLHTTP");
        } catch (e) {
            xmlHttpRequest = new ActiveXObject("Msxml2.XMLHTTP")
        }
    }
}
//这是方法执行功能区
function ckUname(uname) {
    createXMLHttpRequest();//书写createXMLHttpRequest
    var url = "user.do?operate=ckUname&uname="+uname ;
    //open传参数:GET:请求方法  url:向服务器发请求 true:确定发送
    xmlHttpRequest.open("GET",url,true);
    //设置回调函数
    xmlHttpRequest.onreadystatechange = ckUnameCB ;
    //发送请求
    xmlHttpRequest.send();
}
//创建回调函数
function ckUnameCB(){
     //一共有4个状态,当状态为4时,才能使用,所以我们只用4,并且200表示正常
    if(xmlHttpRequest.readyState==4 && xmlHttpRequest.status==200){
        //xmlHttpRequest.responseText 表示 服务器端响应给我的文本内容
        //alert(xmlHttpRequest.responseText);
        var responseText = xmlHttpRequest.responseText;
        if(responseText=="{'uname':'1'}"){
            alert("用户名已经被注册!");
        }else{
            alert("用户名可以注册!");
        }
    }
}

2.服务器的书写

在Controller层
 public String ckUname(String uname) {
        User user = userService.getUser(uname);
        if (user != null) {
            //用户名已经被占用
            return "json:('uname':'1')";

        } else {
            //用户没有没注册
            return "json:('uname':'0')";
        }
    }
}


在DispatcherServlet
 if (methodReturnStr.startsWith("json:")) {
    String jsonStr = methodReturnStr.substring("json:".length());
    PrintWriter out = response.getWriter();
    ut.print(jsonStr);//删掉换行符
    out.flush();
    }

录入回执

在页面显示是否可以用

总结

Ajax:异步的javaScript and XML
目的:用来发送异步请求的,XML和hTTP结合提高用户的体验
目的:提高用户的体验
好处:局部刷新、减轻网络带宽压力、提高效率
创建:xmlHTTpRequst
调用open方法:设置GET和url还有trun
绑定执行的回调函数
发送请求send,如果是post请求就需要设置参数
编写回调函数,我们在回调函数中,我们只对XMLHTTP
xmlHttpRequest.readyState这是响应的内容,我们支队4感兴趣
 xmlHttpRequest.status==200我们只对200感兴趣
在回调函数中:我们用到OreadyState和xmlHttpRequest请求

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值