Java web 2022跟学尚硅谷(十一) Vue基础和Axios基础和json基础

news2025/1/9 23:11:24

Java web 2022跟学尚硅谷十一后端基础 书城

  • Vue
    • 在js中定义对象的2种方式
      • 方式一
      • 方式二
    • 简单的Vue代码
    • 绑定元素的属性
      • 方式一 v-bind:value
      • 方式二 :value
    • 双向数据绑定 v-model:
      • 方式一
      • 方式二 :value可以省略,trim去除首尾空格
    • 条件渲染 v-if
    • 条件渲染 v-else
    • 条件渲染 特别注意
    • 条件渲染 v-show
    • v-show和v-if、v-else的区别
    • 列表渲染 v-for迭代
    • 事件驱动
      • 方式一 v-on:click
      • 方式二 @click
    • 侦听属性 watch
    • 生命周期
    • 总结
  • Axios
    • Axios基本介绍
    • Axios执行的基本步骤
  • 发送请求体json
    • 什么是json
    • JSON特点
    • 客户端发送JSON格式的数据给服务器端
    • 导入jar包 Gson
    • 相关代码 后端接收到数据
      • demo10.html
      • Axios02Servlet
      • User.java
    • 后端接收数据后以json object返回给前端
      • demo11.html
      • Axios03Servlet
    • 前台JSON对象和String的转换
      • js中的String转换成Object
      • js中的Object变成string
    • 书城1.3最终版
      • 购物车添加使用异步请求
        • index.html
        • cart.html
        • CartItemServiceImpl.java
        • CartItemController.java

Vue

在js中定义对象的2种方式

方式一

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title>Title</title>
    <meta content="" charset="UTF-8">
    <!--<script type="" language="JavaScript" src="script/vue.js">-->
    <script type="" language="JavaScript">
        function hello() {
            person.sayHello();
        }

         var person = new Object();
         person.pid = "p01";
         person.pname = "Jim";
         person.sayHello = function () {
             alert("Hello " + person.pid + person.pname);
         }


        window.onload = function () {
            var vue = new Vue({});
        }
    </script>
</head>
<body>
<div id="div0">
    <span>Hello</span>
    <input type="button" value="打招呼" onclick="hello()"></input>
</div>

</body>
</html>

方式二

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title>Title</title>
    <meta content="" charset="UTF-8">
    <!--<script type="" language="JavaScript" src="script/vue.js">-->
    <script type="" language="JavaScript">
        function hello() {
            person.sayHello();
        }

        var person = {
            "pid": "p001",
            "pname": "Tonny",
            sayHello: function () {
                alert("Hello " + person.pid + person.pname);
            }

        }
        window.onload = function () {
            var vue = new Vue({});
        }
    </script>
</head>
<body>
<div id="div0">
    <span>Hello</span>
    <input type="button" value="打招呼" onclick="hello()"></input>
</div>

</body>
</html>

输出结果
输出结果

简单的Vue代码

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title>Title</title>
    <meta content="" charset="UTF-8">
    <script language="JavaScript" src="script/vue.js"></script>
    <script type="" language="JavaScript">
        window.onload = function () {
            var vue = new Vue({
                // # 表示id
                // . 表示class
                "el": "#div0",
                "data": {
                    msg: "hello Rose"
                }
            });
        }
    </script>
</head>
<body>
<div id="div0">
    <span>{{msg}}</span>
</div>

</body>
</html>

绑定元素的属性

方式一 v-bind:value

代码:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title>Title</title>
    <meta content="" charset="UTF-8">
    <script language="JavaScript" src="script/vue.js"></script>
    <script type="" language="JavaScript">
        window.onload = function () {
            var vue = new Vue({
                // # 表示id
                // . 表示class
                "el": "#div0",
                "data": {
                    msg: "hello Rose",
                    uname: "张三丰"
                }
            });
        }
    </script>
</head>
<body>
<div id="div0">
    <span>{{msg}}</span>
    <input type="text" v-bind:value="uname"></input>
</div>

</body>
</html>

效果:
绑定元素的属性

方式二 :value

代码

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title>Title</title>
    <meta content="" charset="UTF-8">
    <script language="JavaScript" src="script/vue.js"></script>
    <script type="" language="JavaScript">
        window.onload = function () {
            var vue = new Vue({
                // # 表示id
                // . 表示class
                "el": "#div0",
                "data": {
                    msg: "hello Rose",
                    uname: "小龙女"
                }
            });
        }
    </script>
</head>
<body>
<div id="div0">
    <span>{{msg}}</span>
    <input type="text" :value="uname"></input>
</div>

</body>
</html>

显示
显示

双向数据绑定 v-model:

方式一

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title>Title</title>
    <meta content="" charset="UTF-8">
    <script language="JavaScript" src="script/vue.js"></script>
    <script type="" language="JavaScript">
        window.onload = function () {
            var vue = new Vue({
                // # 表示id
                // . 表示class
                "el": "#div0",
                "data": {
                    msg: "hello Rose"
                }
            });
        }
    </script>
</head>
<body>
<div id="div0">
    <span>{{msg}}</span><br/>
    <!-- v-model:双向绑定
        也就是说v-bind:是单向绑定,是通过msg这个变量的值来控制input输入框
        现在v-model:不仅msg来控制input输入框,反过来input输入框也会改变msg的值
     -->
    <input type="text" v-model:value="msg"></input>
</div>

</body>
</html>

输出结果:
input里面更改值,span里面也会改变
input里面更改值,span里面也会改变

方式二 :value可以省略,trim去除首尾空格

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title>Title</title>
    <meta content="" charset="UTF-8">
    <script language="JavaScript" src="script/vue.js"></script>
    <script type="" language="JavaScript">
        window.onload = function () {
            var vue = new Vue({
                // # 表示id
                // . 表示class
                "el": "#div0",
                "data": {
                    msg: "hello Rose"
                }
            });
        }
    </script>
</head>
<body>
<div id="div0">
    <span>{{msg}}</span><br/>
    <!-- v-model:双向绑定
        也就是说v-bind:是单向绑定,是通过msg这个变量的值来控制input输入框
        现在v-model:不仅msg来控制input输入框,反过来input输入框也会改变msg的值
     -->
    <input type="text" v-model.trim="msg"></input>
</div>

</body>
</html>

效果
效果

条件渲染 v-if

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title>Title</title>
    <meta content="" charset="UTF-8">
    <script language="JavaScript" src="script/vue.js"></script>
    <script type="" language="JavaScript">
        window.onload = function () {
            var vue = new Vue({
                // # 表示id
                // . 表示class
                "el": "#div0",
                "data": {
                    num: 2
                }
            });
        }
    </script>
</head>
<body>
<div id="div0">
    <input type="text" v-model="num"></input>
    <div v-if="num%2==0" style="width: 200px;height: 200px;background-color: aqua;">&nbsp;</div>
</div>

</body>
</html>

效果1:输入被2整除的数时
效果
效果2:输入不能被2整除的数时
效果2

条件渲染 v-else

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title>Title</title>
    <meta content="" charset="UTF-8">
    <script language="JavaScript" src="script/vue.js"></script>
    <script type="" language="JavaScript">
        window.onload = function () {
            var vue = new Vue({
                // # 表示id
                // . 表示class
                "el": "#div0",
                "data": {
                    num: 2
                }
            });
        }
    </script>
</head>
<body>
<div id="div0">
    <input type="text" v-model="num"></input>
    <div v-if="num%2==0" style="width: 200px;height: 200px;background-color: aqua;">&nbsp;</div>
    <div v-else="num%2==0" style="width: 200px;height: 200px;background-color: crimson;">&nbsp;</div>
</div>

</body>
</html>

输入奇数的时候
输入偶数的时候

条件渲染 特别注意

特别注意 v-if和 v-else中间不能有其它结点或者元素,否则失效

条件渲染 v-show

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title>Title</title>
    <meta content="" charset="UTF-8">
    <script language="JavaScript" src="script/vue.js"></script>
    <script type="" language="JavaScript">
        window.onload = function () {
            var vue = new Vue({
                // # 表示id
                // . 表示class
                "el": "#div0",
                "data": {
                    num: 2
                }
            });
        }
    </script>
</head>
<body>
<div id="div0">
    <input type="text" v-model="num"></input>
    <div v-show="num%2==0" style="width: 200px;height: 200px;background-color: lime;">&nbsp;</div>

</div>

</body>
</html>

显示效果1:
当被2整除的时候,显示方框
效果1
显示效果2:
当不被2整除的时候,不显示方框,源代码增加了一个属性
显示效果2

v-show和v-if、v-else的区别

v-show通过属性display控制标签是否展示,v-if直接将不满足条件的标签移除。
即v-show标签还在,只是不展示,而v-if和v-else不展示的话,标签也不在了。

列表渲染 v-for迭代

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title>Title</title>
    <meta content="" charset="UTF-8">
    <script language="JavaScript" src="script/vue.js"></script>
    <script type="" language="JavaScript">
        window.onload = function () {
            var vue = new Vue({
                // # 表示id
                // . 表示class
                "el": "#div0",
                "data": {
                    fruitList: [
                        {fname: "苹果", price: 6, fcount: 30, remark: "青苹果乐园"},
                        {fname: "香梨", price: 7, fcount: 20, remark: "库尔勒香梨"},
                        {fname: "菠萝", price: 8, fcount: 10, remark: "海南大菠萝"},
                        {fname: "荔枝", price: 9, fcount: 40, remark: "深圳妃子笑"}
                    ]
                }
            });
        }
    </script>
</head>
<body>
<div id="div0">
    <table border="1" width="400" cellpadding="4" cellspacing="0">
        <tr>
            <th>名称</th>
            <th>单价</th>
            <th>库存</th>
            <th>备注</th>
        </tr>
        <tr align="center" v-for="fruit in fruitList">
            <td> {{fruit.fname}}</td>
            <td> {{fruit.price}}</td>
            <td> {{fruit.fcount}}</td>
            <td> {{fruit.remark}}</td>
        </tr>
    </table>
</div>
</body>
</html>

显示结果
显示结果

事件驱动

方式一 v-on:click

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title>Title</title>
    <meta content="" charset="UTF-8">
    <script language="JavaScript" src="script/vue.js"></script>
    <script type="" language="JavaScript">
        window.onload = function () {
            var vue = new Vue({
                // # 表示id
                // . 表示class
                "el": "#div0",
                "data": {msg: "helloworld"},
                methods: {
                    myReverse: function () {
                        this.msg = this.msg.split("").reverse().join("");
                    }
                }
            });
        }
    </script>
</head>
<body>
<div id="div0">
    <span>{{msg}}</span><br/>
    <input type="button" value="反转" v-on:click="myReverse"></input>
</div>
</body>
</html>

显示结果
点击结果1
点击结果2

方式二 @click

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title>Title</title>
    <meta content="" charset="UTF-8">
    <script language="JavaScript" src="script/vue.js"></script>
    <script type="" language="JavaScript">
        window.onload = function () {
            var vue = new Vue({
                // # 表示id
                // . 表示class
                "el": "#div0",
                "data": {msg: "hello Tony"},
                methods: {
                    myReverse: function () {
                        this.msg = this.msg.split("").reverse().join("");
                    }
                }
            });
        }
    </script>
</head>
<body>
<div id="div0">
    <span>{{msg}}</span><br/>
    <!--<input type="button" value="反转" v-on:click="myReverse"></input>-->
    <input type="button" value="反转" @click="myReverse"></input>
</div>
</body>
</html>

反转1
反转2

侦听属性 watch

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title>Title</title>
    <meta content="" charset="UTF-8">
    <script language="JavaScript" src="script/vue.js"></script>
    <script type="" language="JavaScript">
        window.onload = function () {
            var vue = new Vue({
                    // # 表示id
                    // . 表示class
                    "el": "#div0",
                    "data": {
                        num1: 1,
                        num2: 2,
                        num3: 0
                    }, watch: {
                        num1: function (newValue) {
                            this.num3 = parseInt(newValue) + parseInt(this.num2);
                        },
                        num2: function (newValue) {
                            this.num3 = parseInt(this.num1) + parseInt(newValue);
                        }
                    }
                })
            ;
        }
    </script>
</head>
<body>
<div id="div0">
    <span>{{msg}}</span><br/>
    <input type="text" v-model="num1"></input>
    +
    <input type="text" v-model="num2"></input>
    =
    <span>{{num3}}</span>

</div>
</body>
</html>

结果
结果

生命周期

生命周期
相关样例

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title>Title</title>
    <meta content="" charset="UTF-8">
    <script language="JavaScript" src="script/vue.js"></script>
    <script type="" language="JavaScript">
        window.onload = function () {
            var vue = new Vue({
                        // # 表示id
                        // . 表示class
                        "el": "#div0",
                        "data": {
                            msg: "hello"
                        },
                        // vue实例对象创建之前
                        beforeCreate: function () {
                            console.log("beforeCreate: vue对象创建之前");
                            console.log("msg = " + this.msg);
                        },
                        // vue对象创建之后
                        created: function () {
                            console.log("created: vue对象创建之后");
                            console.log("msg = " + this.msg);
                        },
                        // 数据装载之前
                        beforeMount: function () {
                            console.log("beforeMount: 数据装载之前");
                            var spanValue = document.getElementById("span").innerText;
                            console.log("msg = " + spanValue);
                        },
                        // 数据装载之后
                        mounted: function () {
                            console.log("mounted: 数据装载之后");
                            var spanValue = document.getElementById("span").innerText;
                            console.log("msg = " + spanValue);
                        },
                        // 数据更新之前
                        beforeUpdate: function () {
                            console.log("beforeUpdate: 数据更新之前");
                            var spanValue = document.getElementById("span").innerText;
                            console.log("更新的spanValue = " + spanValue);
                            console.log("更新的msg = " + this.msg);
                        },
                        // 数据更新之后
                        updated: function () {
                            console.log("updated: 数据更新之后");
                            var spanValue = document.getElementById("span").innerText;
                            console.log("更新的spanValue = " + spanValue);
                            console.log("更新的msg = " + this.msg);
                        }
                        ,
                        methods: {
                            changeMsg: function () {
                                this.msg = this.msg + "D";
                            }
                        }
                    }
                )
            ;
        }
    </script>
</head>
<body>
<div id="div0">
    <span id="span">{{msg}}</span><br/>
    <input type="button" value="更改msg的值" @click="changeMsg"></input>
</div>
</body>
</html>

图示
图示

总结

Vue
(1) {{}} - 相当于innerText
(2) v-bind:attr 绑定属性值。例如,v-bind:value - 绑定value值
简写: :value
(3) v-model 双向绑定
v-model:value , 简写 v-model
(4) v-if , v-else , v-show
v-if和v-else之间不能有其他的节点
v-show是通过样式表display来控制节点是否显示
(5) v-for 迭代
v-for={fruit in fruitList}
(6) v-on 绑定事件
(7) 其他:

  • trim:去除首尾空格 , split() , join()
  • watch表示侦听属性
  • 生命周期

Axios

Axios基本介绍

Axios是Ajax的一个框架简化Ajax操作

Axios执行的基本步骤

Axios执行Ajax操作的步骤
Axios示例
简单写一个代码样例

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title>Title</title>
    <meta content="" charset="UTF-8">
    <script language="JavaScript" src="script/vue.js"></script>
    <script language="JavaScript" src="script/axios.min.js"></script>
    <script type="" language="JavaScript">
        window.onload = function () {
            var vue = new Vue({
                        // # 表示id
                        // . 表示class
                        "el": "#div0",
                        "data": {
                            uname: "jack",
                            pwd: "ok"
                        },
                        methods: {
                            axios01: function () {
                                axios({
                                    "method": "post",
                                    "url": "axios01.do",
                                    "params": {
                                        "userName": vue.uname,
                                        "pwd": vue.pwd
                                    }
                                }).then(function (response) {
                                    console.log(response);
                                }).catch(function (error) {
                                    console.log(error);
                                });
                            }
                        }
                    }
                )
            ;
        }
    </script>
</head>
<body>
<div id="div0">
    账号:<input type="text" v-model="uname"></input>
    密码:<input type="text" v-model="pwd"></input>
    <input type="button" @click="axios01" value="提交"></input>
</div>
</body>
</html>

java代码

package com.atguigu.axios;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;

/**
 * @ClassName: Axios01Servlet
 * @Description:
 * @Author: wty
 * @Date: 2022/12/15
 */
@WebServlet("/axios01.do")
public class Axios01Servlet extends HttpServlet {
    @Override
    protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        String uname = request.getParameter("uname");
        String pwd = request.getParameter("pwd");

        System.out.println("uname =" + uname);
        System.out.println("pwd" + pwd);

        response.setCharacterEncoding("UTF-8");
        response.setContentType("text/html;charset=utf-8");
        PrintWriter out = response.getWriter();
        out.write(uname + "_" + pwd);

        //throw new NullPointerException("这里故意抛出一个空指针异常....");
    }
}

显示效果
前台接收到后台的返回值
显示效果1
后台的数据成功被前台获取
显示效果2

发送请求体json

什么是json

JSON是一种数据格式
XML也是一种数据格式
XML格式表示两个学员信息的代码如下:

  <students>
    <student sid="s001">
        <sname>jim</sname>
        <age>18</age>
    </student>
    <student sid="s002">
        <sname>tom</sname>
        <age>19</age>
    </student>
  </students>

JSON格式表示两个学员信息的代码如下:

  [{sid:"s001",age:18},{sid:"s002",age:19}]

JSON特点

JSON表达数据更简洁,更能够节约网络带宽

客户端发送JSON格式的数据给服务器端

(1) 客户端中params需要修改成: data:
(2) 服务器获取参数值不再是 request.getParameter()…
而是:

StringBuffer stringBuffer = new StringBuffer("");
BufferedReader bufferedReader = request.getReader();
String str = null ;
while((str=bufferedReader.readLine())!=null){
	stringBuffer.append(str);
}
str = stringBuffer.toString() ;

(3) 我们会发现 str的内容如下:

{"uname":"lina","pwd":"ok"}

服务器端给客户端响应JSON格式的字符串,然后客户端需要将字符串转化成js Object

导入jar包 Gson

导入jar包 Gson

相关代码 后端接收到数据

demo10.html

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title>演示Axios发送json格式给服务器</title>
    <meta content="" charset="UTF-8">
    <script language="JavaScript" src="script/vue.js"></script>
    <script language="JavaScript" src="script/axios.min.js"></script>
    <script type="" language="JavaScript">
        window.onload = function () {
            var vue = new Vue({
                        // # 表示id
                        // . 表示class
                        "el": "#div0",
                        "data": {
                            uname: "jack",
                            pwd: "ok"
                        },
                        methods: {
                            axios02: function () {
                                axios({
                                    "method": "post",
                                    "url": "axios02.do",
                                    "data": {
                                        "uname": vue.uname,
                                        "pwd": vue.pwd
                                    }
                                }).then(function (response) {
                                    console.log(response);
                                }).catch(function (error) {
                                    console.log(error);
                                });
                            }
                        }
                    }
                )
            ;
        }
    </script>
</head>
<body>
<div id="div0">
    账号:<input type="text" v-model="uname"></input>
    密码:<input type="text" v-model="pwd"></input>
    <input type="button" @click="axios02" value="提交"></input>
</div>
</body>
</html>

获取到user对象

Axios02Servlet

package com.atguigu.axios;

import com.atguigu.pojo.User;
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
import com.sun.org.apache.bcel.internal.generic.NEW;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.PrintWriter;

/**
 * @ClassName: Axios02Servlet
 * @Description:
 * @Author: wty
 * @Date: 2022/12/15
 */
@WebServlet("/axios02.do")
public class Axios02Servlet extends HttpServlet {
    @Override
    protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        StringBuffer stringBuffer = new StringBuffer("");

        BufferedReader bufferedReader = request.getReader();
        String str = "";
        while ((str = bufferedReader.readLine()) != null) {
            stringBuffer.append(str);
        }
        str = stringBuffer.toString();
        System.out.println("str = " + str);

        // str = {"uname":"jack","pwd":"ok"}

        // 需要第三方jar包
        // 方式1
        Gson gson = new Gson();

        // 方式2:可以格式化
        //Gson gson1 = new GsonBuilder().create();

        User user = gson.fromJson(str, User.class);
        System.out.println(user);


    }
}

User.java

package com.atguigu.pojo;

/**
 * @ClassName: User
 * @Description:
 * @Author: wty
 * @Date: 2022/12/15
 */

public class User {
    private String uname;
    private String pwd;

    public User() {
    }

    public String getUname() {
        return uname;
    }

    public void setUname(String uname) {
        this.uname = uname;
    }

    public String getPwd() {
        return pwd;
    }

    public void setPwd(String pwd) {
        this.pwd = pwd;
    }

    public User(String uname, String pwd) {
        this.uname = uname;
        this.pwd = pwd;
    }

    @Override
    public String toString() {
        return "User{" +
                "uname='" + uname + '\'' +
                ", pwd='" + pwd + '\'' +
                '}';
    }
}

后台输出结果

str = {"uname":"jack","pwd":"ok"}
User{uname='jack', pwd='ok'}

后端接收数据后以json object返回给前端

demo11.html

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title>演示Axios发送异步请求给服务器,服务器响应请求给客户端</title>
    <meta content="" charset="UTF-8">
    <script language="JavaScript" src="script/vue.js"></script>
    <script language="JavaScript" src="script/axios.min.js"></script>
    <script type="" language="JavaScript">
        window.onload = function () {
            var vue = new Vue({
                        // # 表示id
                        // . 表示class
                        "el": "#div0",
                        "data": {
                            uname: "jack",
                            pwd: "ok"
                        },
                        methods: {
                            axios03: function () {
                                axios({
                                    "method": "post",
                                    "url": "axios03.do",
                                    "data": {
                                        "uname": vue.uname,
                                        "pwd": vue.pwd
                                    }
                                }).then(function (response) {
                                    var data = response.data;
                                    console.log(data);
                                    vue.uname = data.uname;
                                    vue.pwd = data.pwd;
                                }).catch(function (error) {
                                    console.log(error);
                                });
                            }
                        }
                    }
                )
            ;
        }
    </script>
</head>
<body>
<div id="div0">
    账号:<input type="text" v-model="uname"></input>
    密码:<input type="text" v-model="pwd"></input>
    <input type="button" @click="axios03" value="提交"></input>
</div>
</body>
</html>

Axios03Servlet

package com.atguigu.axios;

import com.atguigu.pojo.User;
import com.google.gson.Gson;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.BufferedReader;
import java.io.IOException;

/**
 * @ClassName: Axios03Servlet 
 * @Description:
 * @Author: wty
 * @Date: 2022/12/15
 */
@WebServlet("/axios03.do")
public class Axios03Servlet extends HttpServlet {
    @Override
    protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        StringBuffer stringBuffer = new StringBuffer("");

        BufferedReader bufferedReader = request.getReader();
        String str = "";
        while ((str = bufferedReader.readLine()) != null) {
            stringBuffer.append(str);
        }
        str = stringBuffer.toString();
        System.out.println("str = " + str);

        // str = {"uname":"jack","pwd":"ok"}

        // 需要第三方jar包
        // 方式1
        Gson gson = new Gson();

        // 方式2:可以格式化
        //Gson gson1 = new GsonBuilder().create();

        User user = gson.fromJson(str, User.class);
        user.setUname("小明");
        user.setPwd("1234");
        System.out.println(user);

        // 假设user是数据库查询查来的,需要转换成json格式给客户端
        String userJsonStr = gson.toJson(user);
        response.setCharacterEncoding("UTF-8");
        response.setContentType("application/json;charset=utf-8");
        response.getWriter().write(userJsonStr);

    }
}

输出结果
结果1
将后台的赋值,传到了前台
结果2

前台JSON对象和String的转换

var str = "";
// object → string
JSON.stringify(str);
//  string→ object
JSON.parse(str);

代码示例

js中的String转换成Object

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title>JS中的字符串和Object之间互转的API</title>
    <meta content="" charset="UTF-8">
    <script language="JavaScript" src="script/vue.js"></script>
    <script language="JavaScript" src="script/axios.min.js"></script>
    <script type="" language="JavaScript">
        function hello01() {
            var str = "{\"uname\":\"lina\",\"age\":20}";
            var user = JSON.parse(str);
            alert(typeof user);
            alert(user.uname + "_" + user.age);
        }
    </script>
</head>
<body>
<div id="div0">
    <input type="button" value="提交" onclick="hello01()"></input>
</div>
</body>
</html>

js中的Object变成string

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <title>JS中的字符串和Object之间互转的API</title>
    <meta content="" charset="UTF-8">
    <script language="JavaScript" src="script/vue.js"></script>
    <script language="JavaScript" src="script/axios.min.js"></script>
    <script type="" language="JavaScript">
        function hello01() {
            var str = "{\"uname\":\"lina\",\"age\":20}";
            var user = JSON.parse(str);
            alert(typeof user);
            alert(user.uname + "_" + user.age);
        }

        function hello02() {
            var user = {"uname": "lina", "age": 3};
            alert(typeof user);
            var userStr = JSON.stringify(user);
            alert(userStr);
        }
    </script>
</head>
<body>
<div id="div0">
    <input type="button" value="提交" onclick="hello02()"></input>
</div>
</body>
</html>

书城1.3最终版

购物车添加使用异步请求

index.html

<!--登录后风格-->
            <div class="topbar-right" th:unless="${session.currUser == null}">
                <span>欢迎你<b th:text="${session.currUser.getUname()}">张总</b></span>
                <a href="#" class="register">注销</a>
                <a th:href="@{/page.do(operate='page',page='cart/cart')}" class="cart iconfont icon-gouwuche">
                    购物车
                    <div class="cart-num" th:text="${session.currUser.getCart().getTotalCount()}">3</div>
                </a>
                <a href="./pages/manager/book_manager.html" class="admin">后台管理</a>
            </div>

cart.html

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8"/>
    <meta name="viewport" content="width=device-width, initial-scale=1.0"/>
    <title>Document</title>
    <link rel="stylesheet" th:href="@{/static/css/minireset.css}"/>
    <link rel="stylesheet" th:href="@{/static/css/common.css}"/>
    <link rel="stylesheet" th:href="@{/static/css/cart.css}"/>
    <script language="JavaScript" th:src="@{/static/script/vue.js}"></script>
    <script language="JavaScript" th:src="@{/static/script/axios.min.js}"></script>
    <script language="JavaScript" th:src="@{/static/script/cart.js}">

    </script>
</head>
<body>
<div class="header">
    <div class="w">
        <div class="header-left">
            <a th:href="@{/index.html}">
                <img th:src="@{/static/img/logo.gif}" alt=""
                /></a>
            <h1>我的购物车</h1>
        </div>
        <div class="header-right">
            <h3>欢迎<span th:text="${session.currUser.getUname()}">张总</span>光临尚硅谷书城</h3>
            <div class="order"><a th:href="@{/order.do(operate='getOrderList')}">我的订单</a></div>
            <div class="destory"><a href="../../index.html">注销</a></div>
            <div class="gohome">
                <a href="../../index.html">返回</a>
            </div>
        </div>
    </div>
</div>
<div class="list" id="cart_div">
    <div class="w">
        <table>
            <thead>
            <tr>
                <th>图片</th>
                <th>商品名称</th>

                <th>数量</th>
                <th>单价</th>
                <th>金额</th>
                <th>操作</th>
            </tr>
            </thead>
            <tbody>
            <!--<tr th:each="cartItem : ${session.currUser.getCart().getMap().values()}">-->
            <tr v-for="cartItem in cart.map">
                <td>
                    <!--<img th:src="@{|/static/uploads/${cartItem.getBook().getBookImg()}|}" alt=""/>-->
                    <img v-bind:src="'static/uploads/'+cartItem.book.bookImg" alt=""/>
                </td>
                <!--<td th:text="${cartItem.getBook().getBookName()}">活着</td>-->
                <td>{{cartItem.book.bookName}}</td>
                <td>
                    <!--<span class="count" th:disabled="${cartItem.getBuyCount()==1}"-->
                    <!--      th:οnclick="|editCartMinus(${cartItem.id},${cartItem.buyCount})|">-</span>                    -->
                    <!--    <input class="count-num" type="text" th:value="${cartItem.getBuyCount()}"/>-->
                    <!--    <span class="count"-->
                    <!--          th:οnclick="|editCartAdd(${cartItem.id},${cartItem.buyCount},${cartItem.getBook().getBookCount()})|">+</span>-->
                    <!--</td>-->
                    <!--<td th:text="${cartItem.getBook().getPrice()}">36.8</td>-->
                    <!--<td th:text="|小计:${cartItem.getXj()}|">36.8</td>-->
                    <!--<td><a href="">删除</a></td>-->
                    <span class="count" v-bind:disabled="cartItem.buyCount==1"
                          v-on:click="editCartMinus(cartItem.id,cartItem.buyCount)">-</span>
                    <input class="count-num" type="text" v-bind:value="cartItem.buyCount"/>
                    <span class="count"
                          v-on:click="editCartAdd(cartItem.id,cartItem.buyCount,cartItem.book.bookCount)">+</span>
                </td>
                <td>{{cartItem.book.price}}</td>
                <td>{{cartItem.xj}}</td>
                <td><a href="">删除</a></td>
            </tr>
            </tbody>
        </table>
        <div class="footer">
            <div class="footer-left">
                <a href="#" class="clear-cart">清空购物车</a>
                <a href="#">继续购物</a>
            </div>
            <div class="footer-right">
                <!--<div>共<span th:text="${session.currUser.getCart().getTotalBookCount()}">3</span>件商品</div>-->
                <!--<div class="total-price">总金额<span th:text="${session.currUser.getCart().getTotalMoney()}">99.9</span>元-->
                <div><span>{{cart.totalBookCount}}</span>件商品</div>
                <div class="total-price">总金额<span>{{cart.totalMoney}}</span></div>
                <a class="pay" th:href="@{/order.do(operate='checkout')}">去结账</a>
            </div>
        </div>
    </div>
</div>
<div class="bottom">
    <div class="w">
        <div class="top">
            <ul>
                <li>
                    <a href="">
                        <img th:src="@{/static/img/bottom1.png}" alt=""/>
                        <span>大咖级讲师亲自授课</span>
                    </a>
                </li>
                <li>
                    <a href="">
                        <img th:src="@{/static/img/bottom.png}" alt=""/>
                        <span>课程为学员成长持续赋能</span>
                    </a>
                </li>
                <li>
                    <a href="">
                        <img th:src="@{/static/img/bottom2.png}" alt=""/>
                        <span>学员真是情况大公开</span>
                    </a>
                </li>
            </ul>
        </div>
        <div class="content">
            <dl>
                <dt>关于尚硅谷</dt>
                <dd>教育理念</dd>
                <!-- <dd>名师团队</dd>
                <dd>学员心声</dd> -->
            </dl>
            <dl>
                <dt>资源下载</dt>
                <dd>视频下载</dd>
                <!-- <dd>资料下载</dd>
                <dd>工具下载</dd> -->
            </dl>
            <dl>
                <dt>加入我们</dt>
                <dd>招聘岗位</dd>
                <!-- <dd>岗位介绍</dd>
                <dd>招贤纳师</dd> -->
            </dl>
            <dl>
                <dt>联系我们</dt>
                <dd>http://www.atguigu.com</dd>
                <dd></dd>
            </dl>
        </div>
    </div>
    <div class="down">
        尚硅谷书城.Copyright ©2015
    </div>
</div>
</body>
</html>

CartItemServiceImpl.java

    /**
     * @param
     * @return java.util.List<com.atguigu.book.pojo.CartItem>
     * @description 获取指定用户的所有购物车项列表,需要注意方法内部会查询book的详细信息
     * @param: user
     * @date 2022/12/13 17:59
     * @author wty
     **/
    @Override
    public List<CartItem> getCartItemList(User user) {
        List<CartItem> cartItemList = cartItemDAO.getCartItemList(user);
        for (CartItem cartItem : cartItemList) {
            Book book = bookService.getBook(cartItem.getBook().getId());
            cartItem.setBook(book);
            // 此处需要计算小计,执行内部代码让book的price * buyCount
            cartItem.getXj();
        }

        return cartItemList;
    }

CartItemController.java

    public String editCart(Integer cartItemId, Integer buyCount) {
        cartItemService.updateCartItemBuyCount(new CartItem(cartItemId, buyCount));
        return "";
    }

    public String cartInfo(HttpSession session) {
        User currUser = (User) session.getAttribute("currUser");
        Cart cart = cartItemService.getCart(currUser);

        // 调用Cart中的三个属性get方法,目的是计算值,否则为null
        cart.getTotalMoney();
        cart.getTotalCount();
        cart.getTotalBookCount();

        Gson gson = new Gson();
        String cartJsonStr = gson.toJson(cart);
        return "json:" + cartJsonStr;
    }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/95088.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

[附源码]Python计算机毕业设计高校医务管理系统Django(程序+LW)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程 项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等…

极地土活性层和永久冻土的比较宏基因组学

北极地区有大约87%由低有机碳矿物土壤组成&#xff0c;但对低碳永久冻土&#xff08;PF&#xff09;和活性层&#xff08;AL&#xff09;土壤中微生物活性的了解仍然有限。多种物理和生物因素可能影响碳循环&#xff0c;包括土壤化学、氮等养分的可用性以及现有微生物群落的结构…

论文解析[9] Swin Transformer: Hierarchical Vision Transformer using Shifted Windows

发表时间&#xff1a;2021 论文地址&#xff1a;https://arxiv.org/abs/2103.14030 代码地址&#xff1a;https://github.com/microsoft/Swin-Transformer 文章目录摘要3 方法3.1 总体框架3.2 基于自注意力的移动窗口3.3 结构变形5 结论摘要 这篇论文提出了一个新的ViT叫作Swi…

大数据培训kettle安装部署

kettle安装部署和使用 2.1 kettle安装地址 官网地址 https://community.hitachivantara.com/docs/DOC-1009855 下载地址 https://sourceforge.net/projects/pentaho/files/Data%20Integration/ 2.2 Windows下安装使用 2.2.1 概述 在实际企业开发中&#xff0c;都是在本…

Html 小功能总结二

文章目录一、Html 实现弹窗的实例二、Html 实现流程图三、制作一个简单的菜单功能一、Html 实现弹窗的实例 <!DOCTYPE html> <html> <head><meta charset"utf-8" /><title></title><style type"text/css">body…

C++ Reference: Standard C++ Library reference: Containers: map: map: crbegin

C官网参考链接&#xff1a;https://cplusplus.com/reference/map/map/crbegin/ 公有成员函数 <map> std::map::crbegin const_reverse_iterator crbegin() const noexcept;返回指向反向开始的const_reverse_iterator 返回一个指向容器中最后一个元素的const_reverse_ite…

Nacos 消息通知系统 源码讲解

目录 1. 介绍 2. Nacos 中的生产者 3. Nacos 中的消费者 4. Nacos 中的事件 5. 统一事件通知中心 NotifyCenter 6. 总结 1. 介绍 Nacos 节点内部使用了大量的事件机制进行通信&#xff0c;这样各种操作进行了解耦&#xff0c;提高了性能。 接下来就介绍。 所谓事件机制…

virtualenv系列 (5) · 打通virtualenvwrapper和PyCharm/IntelliJ IDEA的虚拟环境

PyCharm/IntelliJ IDEA已经内置了对virtualenv的支持&#xff0c;当我们为一个项目创建一个新的Python SDK时&#xff0c;就会进入到Add Python Interpreter对话框&#xff0c;选择Virtualenv Environment -> New environment就将创建一套新的virtualenv环境。这里&#xff…

关于长三角某高校能效管理平台应用成效探讨

更多请关注&#xff1a;安科瑞电气网 摘要&#xff1a; 随着现代科学技术的发展&#xff0c;在高校中开始广泛应用智能化技术&#xff0c;改善学生宿舍的用电管理模式&#xff0c;提高宿舍的管理水平&#xff0c;有利于实现高校宿舍用电管理的科学化。本文主要阐述传统高校宿…

D2. Seating Arrangements (hard version)(贪心+排序)

Problem - 1566D2 - Codeforces 这是该问题的困难版本。唯一的区别是&#xff0c;在这个版本中&#xff0c;1≤n≤300。 电影院的座位可以表示为有n行和m列的表格。每行的座位都用1到n的整数编号&#xff0c;从左到右连续编号&#xff1a;在第k行&#xff0c;从m(k-1)1到mk&am…

前端的视角聊聊如何快速入门Python

对于 NodeJs 开发的小伙伴&#xff0c;使用 node-gyp 将 C 模块转换成 NodeJs 的 addon 插件时会依赖 Python 的安装环境&#xff08;针对使用了 nvm 等版本管理工具的情况&#xff09;。对于前端小伙伴来说&#xff0c;Python 本身确实不是一个必须学习的语言&#xff0c;但也…

提前做好网络安全分析,运维真轻松(一)

背景 某汽车总部已部署NetInside流量分析系统&#xff0c;使用流量分析系统提供实时和历史原始流量。汽车配件电子图册系统是某汽车集团的重要业务系统。本次分析重点针对汽车配件电子图册系统进行预见性分析&#xff0c;以供安全取证、性能分析、网络质量监测以及深层网络分析…

SQL基础——聚合与排序

聚合与排序前言思维导图聚合函数示例表3-1![在这里插入图片描述](https://img-blog.csdnimg.cn/9c286053f87a4ae882bece8128bdcab5.png)计算表中数据的行数 COUNT函数示例代码3.1 计算全部数据的行数执行结果计算NULL之外的数据的行数代码示例3.2 计算NULL之外的数据行数执行结…

【DevOps实战系列】第五章:基于Gitlab/Maven/Jenkins/Docker实战案例详解

个人亲自录制全套DevOps系列实战教程 &#xff1a;手把手教你玩转DevOps全栈技术 从创建Jenkins的job开始 1.gitlab设置&#xff1a; 我们从新建一个jenkins任务开始&#xff0c;建一个自由风格项目&#xff0c;我们暂时只让他能拉取git的代码。 路径&#xff1a;从gitlab上新…

【ML笔记】5、支持向量机(SVM)

支持向量机&#xff08;SVM&#xff09;是一个强大的和通用的ML模型&#xff0c;能够执行分类&#xff0c;回归&#xff0c;甚至异常值检测&#xff0c;特别适合于复杂的中小型数据集。 1、线性SVM分类 我们可以看到&#xff0c;这两个类可以很容易地用一条直线(线性可分)分开…

GAN入门知识

GAN入门知识 结构 正式说 GAN 之前我们先说一下判别式模型和生成式模型。 判别器 判别式模型 判别式模型&#xff0c;即 Discriminative Model&#xff0c;又被称为条件概率模型&#xff0c;它估计的是条件概率分布(conditional distribution)&#xff0c; p(class|context) 。…

图书网上商店

开发工具(eclipse/idea/vscode等)&#xff1a; 数据库(sqlite/mysql/sqlserver等)&#xff1a; 功能模块(请用文字描述&#xff0c;至少200字)&#xff1a; 1

docker-compose安装部署kafka

文章目录前言一、环境信息二、准备部署1.准备路径2.安装docker-compse&#xff0c;下载镜像3.生成yml文件2.执行部署三、登陆页面前言 记录一下使用docker-compose部署kafka平台的过程 参考&#xff1a;https://blog.csdn.net/QQ83512272/article/details/126368978 一、环境信…

Socket Websocket 客户端和服务端实现

最近在写一个上位机&#xff0c;用到了Websocket&#xff0c;这里就整理一下&#xff0c;顺便把Socket的东西也整理的了&#xff0c;方便以后查阅。 Socket Websocket 客户端和服务端实现Socket客户端和服务端实现Socket客户端Socket服务端实现效果Websocket 客户端和服务端实现…

QT Linux环境搭建——VM虚拟机和Ubuntu的安装

1、从ubuntu官网上下载iso镜像文件&#xff0c;该镜像文件用于安装linux操作系统&#xff0c;以下微官网链接 Enterprise Open Source and Linux | Ubuntu 选择一个最新的稳定版本下载即可&#xff08;好处是&#xff0c;不需要像一些别的网站&#xff0c;必须要注册&#xff…