使用Ajax完成与后台服务器的数据交互

发布于:2025-03-06 ⋅ 阅读:(15) ⋅ 点赞:(0)

使用Ajax实现与后台服务器的数据交互


Ajax(异步的JavaScript和XML)

##注意Ajax为异步

异步:即为不同步,同步相当于是我们在向后台发送请求的时候,必须返回一个响应数据才可以在浏览器下一步操作

(形象描述:一次聊天,两者进行一问一答)–》这就叫做同步

异步就是一者向另外一者发送信息,但是不等对方回复,可以继续向其发送信息


**Ajax与服务器之间进行交换数据,更新的是部分网页的信息,而不是将整个网页进行更新操作。**相当于在注册界面的时候,用户名,密码校验就算有一方未通过但是另外一方任然保留信息,而不需要像同步的那样去更新整个网页


Ajax的交互原理:

Ajax支持异步访问,网页局部刷新,主要依赖于核心对象:XMLHttpRequest,Ajax就是通过XMLHttpRequest对象发送异步请求的


通过axios事项Ajax的异步操作:

axios为链式编程,每调用一个方法返回一个对象

axios.get().then().catch().finally();

then方法执行在后台响应成功的时候

catch方法执行在出现Ajax请求异常的时候

finally方法不论请求响应成功与否都要执行的方法

导入axios:

<script src="js/axios-0.18.0.js"></script>

使用axios对象调用函数向后台服务器发送ajax的get异步请求

/*整体: axios.get().then().catch().finally();*/
          1)get()函数表示两后台服务器发送get请求,格式:
              get(url?key=value&key=value...);===axios.get("/axiosDemo01Servlet?username=axios&password=1234")
          2)then() 处理后台服务器响应的,格式:
                then(function(接收响应数据的对象名){
                    处理响应的代码
                });

                then(function (resp){
                 console.log(resp);
             })
             后台响应数据:
                resp={
                        data: 'axios实现ajax异步get请求,username=锁哥',
                        status: 200,
                        statusText: '',
                        headers: {},
                        config: {},
                    }

                resp.data就可以获取 数据: axios实现ajax异步get请求,username=锁哥

          3)catch() :处理异常
                catch(function (error) {
                    console.log(error);
                })

                let person ={
                    username:"锁哥",
                    age:18
                }

使用axios对象调用函数向后台服务器发送ajax的post异步请求

<script type="text/javascript">
    //1.使用axios对象调用函数向后台服务器发送ajax异步请求
    /*
        整体: axios.post().then().catch().finally();
          1)post()函数表示向后台服务器发送post请求,格式:
              post(url,key=value&key=value...);===axios.post("/axiosDemo01Servlet","username=锁哥&password=1234")
          2)then() 处理后台服务器响应的,格式:
                then(function(接收响应数据的对象名){
                    处理响应的代码
                });
            其实在then函数中的回调函数我们可以使用es6的新语法,箭头函数:
                (参数)=>{函数体}
            格式:
            then(resp=>{
                    函数体
            });
     */
    /*
             说明:
                1.http://localhost:8080/axiosDemo03Servlet 表示后台服务器地址
                2.username=锁哥&password=1234:表示向后台携带的参数
    */
    //使用es6的箭头函数简化上述回调函数的写法
    // TODO:post方法的URL和请求参数之间用逗号分隔
    axios.post("http://localhost:8080/axiosDemo03Servlet","username=Java&password=1234")
        .then(Response=>{
            //后台响应成功相应数据
            console.log(Response);
        })
        .catch(error=>{
            //后台响应失败相应数据
            console.log(error);
            console.log("响应失败");
        })
        .finally(()=>{
            //无论响应成功还是失败都要执行的代码
            console.log("无论响应成功还是失败都要执行的代码");
        });

</script>

综合案例:

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<form action="">
    <input type="text" name="username" placeholder="请输入用户名" id="username">
    <span id="usernameSpan"></span>
    <br>
    <input type="password" name="password" placeholder="请输入密码"> <br>
    <button>提交</button>
</form>
<!--  导入axios类库  -->
<script type="text/javascript" src="js/axios-0.18.0.js"></script>
<script type="text/javascript">
    /*
        说明:
            1.后台地址url:"http://localhost:8080/registerServlet"
            2.后台需要根据key即参数名是username来获取前端提交的用户名数据
            3.后台已经存在的用户名是:"岩岩"
     */
    //1、给用户名输入框绑定离焦事件
    document.getElementById("username").onblur=()=>{
        //2、获取用户名输入框中的数据
        //this表示当前事件onblur的标签对象document.getElementById("username")
        let usernameValue=document.getElementById('username').value;
        // let usernameValue=this.value;
        console.log(usernameValue);
        //判断是否输入数据
        //trim() 方法用于删除字符串的头尾空白符再返回字符串
        if(usernameValue.trim()!=''){
           //此逻辑表示用户名输入框中有数据
            //3、向后台发送ajax请求
            axios.post("http://localhost:8080/registerServlet","username="+usernameValue)
            .then(resp => {
                //4、处理响应数据
                // console.log(resp);
                if(resp.data){
                    document.getElementById("usernameSpan").innerHTML="用户名可用";
                    //通过JS代码实现css样式设置字体颜色为绿色
                    document.getElementById("usernameSpan").style.color="green";
                }else{
                    document.getElementById("usernameSpan").innerHTML="用户名不可用";
                    //通过JS代码实现css样式设置字体颜色为红色
                    document.getElementById("usernameSpan").style.color="red";
                }
            });
        }
    }
</script>
</body>

</html>

网站公告

今日签到

点亮在社区的每一天
去签到