前言
这一节讲JavaWeb之AJAX
1.概述

 
 以前我们在servlet中得到数据,必须通过域给jsp,然后jsp在响应给浏览器
纯html不能获取servlet返回数据
 所以我们用jsp
 但是现在我们可以同AJAX给返回数据了
 我们可以在sevlet中直接通过AJAX返回给浏览器
 html中的JavaScript就可以获取数据了
 通过静态的html页面和AJAX联合起来,这个比较主流
 这样html和AJAX主要由前端来完成就可以了
 后面的我们后端来完成
 因为jsp要由服务器启动,所以还是要后端来写,无法分工
 
 

 这个搜索的时候,我们没有刷新,它也会局部刷新,在数据库中打出的这些数据
 或者我们输入用户名,鼠标一离开就会显示有没有这个用户
 
 这种局部刷新就是异步
 
 这里的异步就是服务器处理的三秒钟内,我们不用再浏览器等待,我们还可以干其他事情
同步左上角是会刷新的,异步就不会刷新显示出来
 这个对于用户来说,没什么感知
2. 快速入门

第一就是后端代码,其余的都是前端代码
 
 这个就是后端代码
Ajax是JavaScript的代码,要写在html里面去
https://www.w3school.com.cn/b.asp
 这个网站有相关的教程
 
 
 
 
 
 异步是默认的,所以可以不用写

 这个就是全路径


 点的是下一页
 
 

 但我们这个不能运行出我们想要的结果,可能是第一步创建搞错了
    <script>
        //1.创建核心对象,不用记,直接复制
        var xhttp;
        if (window.XMLHttpRequest) {
            xhttp = new XMLHttpRequest();
        }else{
            xhttp = new ActiveXObject("Microsoft.XMLHTTP");
        }
        //2.发送请求
        xhttp.open("GET", "http://localhost:8080/brand-demo/ajaxServlet");//第二个参数就是你要请求的资源路径,异步的话,资源要写成全路径:http://localhost:8080/brand-demo/ajaxServlet
        //因为将来前端就是html+ajax开发了,前端的工程和后端的工程都不在一个服务器上部署,所以访问的话就要写绝对路径了,不要写相对路径了
        xhttp.send();
        //3.获取响应
        xhttp.onreadystatechange = function() {
            if (this.readyState == 4 && this.status == 200) {
                    // this.responseText;//获取数据,就是我们返回的hello ajax~数据
                alert(this.responseText);//在一个弹框里面打印
            }
        };
    </script>

 我们这个修改后就可以了
 
 
 那个servlet的xhr就是异步请求的意思

 或者直接点这个上面的XHR,也可以筛选出来我们需要的异步请求
所以所谓AJAX其实也就是JavaScript里面可以获取响应数据的代码
3. 案例-验证用户是否存在

3.1 后端
        //1.接收用户名
        String username = request.getParameter("username");
        //2.调用service查询User对象,,,,,现在还没写service,我们只是模拟一下
        boolean flag = true;//相当于用户名存在
        //3.响应标记
        response.getWriter().write(""+flag);

3.2 前端
注册页面
 这个注册页面可以去我的Gitee里面去找
 这里我就直接复制了
 而且这个不重要

 
这个就是我们以前的那个页面

 我们就可以对这个username绑定一个onblur事件
 
 修改style那里
 
 
<script>
    //1.给用户名输入框绑定  失去焦点事件
    document.getElementById("username").onblur=function(){
        //2.发送ajax
        //获取用户名的值  这个是给自己的输入框绑定的onblur事件,直接可以this
        var username=this.value;
        //2.1.创建核心对象,不用记,直接复制
        var xhttp;
        if (window.XMLHttpRequest) {
            xhttp = new XMLHttpRequest();
        }else{
            xhttp = new ActiveXObject("Microsoft.XMLHTTP");
        }
        //2.2.发送请求
        xhttp.open("GET", "http://localhost:8080/brand-demo/selectUserServlet?username="+username);//把名字通过get传给servlet
        xhttp.send();
        //2.3.获取响应-------》获取的是对应servlet的响应
        xhttp.onreadystatechange = function() {
            if (this.readyState == 4 && this.status == 200) {
                if(this.responseText == "true"){//responseText获取的是字符串
                    //用户名存在,显示提示信息
                    document.getElementById("username_err").style.display='';//显示的话,display就是空字符串就可以了
                }else{
                    //用户名不存在,清除提示信息-----》把style的属性设置一下
                    document.getElementById("username_err").style.display='none';//这个就是设置style为不展示
                }
            }
        };
    }
</script>
因为我们后台展示的是true,所以不管我们写什么,都是用户名已存在
 
 
 
 
 光标离开就会发送一次请求,而且请求还是xhr的异步请求
 
 而且这个请求响应的数据还是true
4. Axios异步框架
4.1 基本使用

 
 
 axios文件也是直接复制就可以了
 
 在创建一个html文件
 02-axios-demo.html:

 AxiosServlet:
 
02-axios-demo.html:
<!--引入axios的源码文件-->
<script src="js/axios-0.18.0.js"></script>
<script>
  //1.get
  axios({
    method:"get",
    // url就是我们请求的路径,就是servlet的路径     .then就是来获取响应的
    url:"http://localhost:8080/ajax-demo/axiosServlet?username=zhangsan"
  }).then(function(resp){
    alert(resp.data);//这个就能获取到响应的数据---》hello axios
  })
</script>

 
 这样我们就可以了

 02-axios-demo.html:
  axios({
    method:"post",
    // url就是我们请求的路径,就是servlet的路径     .then就是来获取响应的
    url:"http://localhost:8080/ajax-demo/axiosServlet",
    data:"username=zhangsan"
  }).then(function(resp){
    alert(resp.data);
    // //这个就能获取到响应的数据---》hello axios
  })

 这样就是post的了
 
 
 这个就要比原生的ajax代码要简化很多
4.2 请求方式别名


  axios.get("http://localhost:8080/ajax-demo/axiosServlet?username=zhangsan").then(function (res) {
      alert(res.data);
  })


 
  axios.post("http://localhost:8080/ajax-demo/axiosServlet","username=zhangsan").then(function (res) {
      alert(res.data);
  })

 
5. JSON

所以我们响应数据都用JSON了
5.1 基本语法

    <script>
        //定义json
        var json={
            "name":"zhangsan",
            "age":23,
            "addr":["北京","上海","西安"]
        };
        //获取值
        alert(json.name);
    </script>

 
5.2 JSON数据和Java对象转换


    <dependency>
      <groupId>com.alibaba</groupId>
      <artifactId>fastjson</artifactId>
      <version>1.2.62</version>
    </dependency>
下面这个是user对象
 
 测试方法
        //1.将Java对象转换为JSON字符串
        User user = new User();
        user.setId(1);
        user.setUsername("zhangsan");
        user.setPassword("123");
        
        String jsonString= JSON.toJSONString(user);
        System.out.println(jsonString);

 
        User u = JSON.parseObject("{\"id\":1,\"password\":\"123\",\"username\":\"zhangsan\"}", User.class);
        System.out.println(u);

6. 案例
6.1 查询所有


 现在我们导入一个工程
 
 
 brand.html:
 
<script>
    //1.当页面加载完成之后,发送ajax请求
    //创建一个窗口,并添加事件,这个事件是在整个页面加载完成之后,自动加载的
    window.onload = function () {
        //2.发送ajax请求
        axios({
            method: 'get',
            url:""
            
        }).then(function (resp) {
            
        })
    }
</script>

 SelectAllServlet:
        //1.调用service查询
        List<Brand> brands = brandService.selectAll();
        //2.将集合转换为JSON数据   序列化
        String jsonString = JSON.toJSONString(brands);
        //3.响应数据
        response.setContentType("text/json;charset=utf-8");//处理中文
        response.getWriter().write(jsonString);

 测试一下
 
 brand.html:
 
测试一下

 因为原来的表格一旦完成就马上执行这个了,所以看不到原来的表格
<script src="js/axios-0.18.0.js">
</script>
<script>
    //1.当页面加载完成之后,发送ajax请求
    //创建一个窗口,并添加事件,这个事件是在整个页面加载完成之后,自动加载的
    window.onload = function () {
        //2.发送ajax请求
        axios({
            method: 'get',
            url:"http://localhost:8080/brand1-demo/selectAllServlet"
        }).then(function (resp) {
            //获取数据,遍历数组
            let brands = resp.data;//这个就是数组,,,,,也是JSON数据    直接点加Data名称就可以获得数据
            let tableData="    <tr>\n" +
                "        <th>序号</th>\n" +
                "        <th>品牌名称</th>\n" +
                "        <th>企业名称</th>\n" +
                "        <th>排序</th>\n" +
                "        <th>品牌介绍</th>\n" +
                "        <th>状态</th>\n" +
                "        <th>操作</th>\n" +
                "    </tr>";
            for (let i = 0; i < brands.length; i++) {
                let brand = brands[i];//放入表格里面去
                tableData+="    <tr align=\"center\">\n" +
                    "        <td>"+(i+1)+"</td>\n" +
                    "        <td>"+brand.brandName+"</td>\n" +
                    "        <td>"+brand.companyName+"</td>\n" +
                    "        <td>"+brand.ordered+"</td>\n" +
                    "        <td>"+brand.description+"</td>\n" +
                    "        <td>"+brand.status+"</td>\n" +
                    "\n" +
                    "        <td><a href=\"#\">修改</a> <a href=\"#\">删除</a></td>\n" +
                    "    </tr>";
            }
            document.getElementById("brandTable").innerHTML=tableData;//设置表格数据
        })
    }
</script>

6.2 新增品牌

 addBrand.html:
 
 AddServlet:
 
 测试一下
 
 
 这样就说明了getParameter方法无法获取JSON的数据格式
 这个不能接受JSON数据格式,,因为这个是把字符串按照&和等号切割的,JSON是没有的,{brandName: “华为”},它长这个样子

 
        //1.接收数据
//        String brandName = request.getParameter("brandName");//这个不能接受JSON数据格式,,因为这个是把字符串按照&和等号切割的,JSON是没有的,{brandName: "华为"},它长这个样子
//        System.out.println(brandName);
        //获取请求体数据
        BufferedReader br = request.getReader();
        String params = br.readLine();//因为json只有一行
        //将JSON字符串转为Java对象
        Brand brand= JSON.parseObject(params, Brand.class);
        System.out.println(brand);
        //2.调用service添加
        brandService.add(brand);
        //3.响应成功标识
        response.getWriter().write("success");

 addBrand.html:
 
 最后就是Data那里,数据必须是真实的
现在开始处理一下表单的数据—》转为JSON
<script src="js/axios-0.18.0.js">
</script>
<script>
// <!--    我们不需要正常提交表单了,---》直接一个普通的按钮就可以了,不用submit按钮了,因为我们要的是异步的,
// 传递的是异步的请求格式,,所以不需要指定action,因为指定了action,就会url变-->
// 1.给按钮绑定单击事件
document.getElementById("btn").onclick = function () {
    //点击提交按钮,数据都填了----->document.getElementById("brandName").value--->就是获取brandName你填写的值
    // var formData={
    //     brandName:document.getElementById("brandName").value,
    //     companyName:document.getElementById("companyName").value,
    //     ordered:document.getElementById("ordered").value,
    //     description:document.getElementById("description").value,
    //     status:document.getElementById("status").value,
    // }
    //或者这样
    var formData={
        brandName:"",
        companyName:"",
        ordered:"",
        description:"",
        status:""
    }
    let brandName=document.getElementById("brandName").value;//获取数据
    formData.brandName=brandName;//设置数据
    let companyName=document.getElementById("companyName").value;//获取数据
    formData.companyName=companyName;//设置数据
    let ordered=document.getElementById("ordered").value;//获取数据
    formData.ordered=ordered;//设置数据
    let description=document.getElementById("description").value;//获取数据
    formData.description=description;//设置数据
    // let status=document.getElementById("brandName").value;//获取数据
    // formData.brandName=brandName;//设置数据
    //但是status没有id,状态是禁用还是启用?,它有两个标签的--》一次性获取两个标签,哪个被选中了就是谁
    let status=document.getElementsByName("status");
    for(let i=0;i<status.length;i++){
        if(status[i].checked){//表示这个被选中了{
            formData.status=status[i].value;
        }
    }
    console.log(formData);//把这个打印到控制台上
    //2。发送ajax请求
    axios({
        method: 'post',
        url:"http://localhost:8080/brand1-demo/addServlet",
        data:formData
    }).then(function (resp) {
        //判断响应数据是否为success,如果是说明添加成功,并跳回展示页面
        if(resp.data =="success"){
            location.href="http://localhost:8080/brand1-demo/brand.html";
        }
    })
}
</script>


 
 
 
总结
下一节讲Vue
 Gitee



















