IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 【Ajax-SSM】第三课 车型管理系统-添加及修改功能 -> 正文阅读

[JavaScript知识库]【Ajax-SSM】第三课 车型管理系统-添加及修改功能

概念

本文完成添加及修改车型信息的功能。

添加功能实现

在index.html首页中给添加按钮设定点击事件,用于展示添加信息页面:

//定义方法,跳转至添加页面
        function add() {
            location.href="addCar.html";
        }

在web文件夹中新建html文件,完成添加页面,addCar.html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>添加车型信息</title>
    <style>
        table{
            width: 600px;
            height: 400px;
            padding: 10px;
            background-color:cornflowerblue ;
            border-width: 0px;
            border-radius: 6px;
            text-align: center;
            color: white;
            font-weight: bold;
        }
        #sub{
            background-color: darkcyan;
            color: white;
            font-weight: bold;
            border-width: 0px;
            border-radius: 6px;
            width: 200px;
            padding: 10px 20px;
        }
        #sub:hover{
            background-color:#648B87 ;
        }
    </style>
</head>
<body>
<div align="center">
    <form action="add.do" method="post">
        <table>
            <tr>
                <th colspan="2">新增品牌</th>
            </tr>
            <tr>
                <td>车型名称</td>
                <td><input type="text" name="carName" placeholder="请输入车型名称"></td>
            </tr>
            <tr>
                <td>品牌名称</td>
                <td><input type="text" name="brandName" placeholder="请输入品牌名称"></td>
            </tr>
            <tr>
                <td>官方价格</td>
                <td><input type="number" name="price" placeholder="请输入价格"></td>
            </tr>
            <tr>
                <td>点击量</td>
                <td><input type="number" name="click" placeholder="请输入点击量"></td>
            </tr>
            <tr>
                <td colspan="2"><input type="submit" id="sub" value="添加"></td>
            </tr>
        </table>
    </form>
</div>
</body>
</html>

?其界面效果如下:

当点击添加按钮,表单将数据提交给服务器add.do地址请求,控制器中定义方法接收数据,并封装,将数据发送给业务逻辑层:

/定义方法,接收页面发送过来的数据
    @RequestMapping("/add.do")
    public String addCar(@RequestParam String carName,@RequestParam String brandName,@RequestParam double price,@RequestParam int click){
        Map<String,Object> map=new HashMap<>();
        map.put("carName",carName);
        map.put("brandName",brandName);
        map.put("price",price);
        map.put("click",click);
        System.out.println(map);
        int i= service.addCar(map);
        return "index.html";
    }

?业务逻辑层中定义方式接收数据:

int addCar(Map<String, Object> map);
 @Override
    public int addCar(Map<String, Object> map) {
        return dao.add(map);
    }

并将数据递交给dao层执行添加的sql语句

 @Insert("insert into car values(#{id},#{carName},#{brandName},#{price},#{click})")
    int add(Map<String, Object> map);

执行成功后,跳转回首页列表页面。

修改功能实现

给index.html首页的修改按钮添加点击事件,并将要修改的车型信息的编号发送出去:

在javascript中定义方法,将编号发送给服务器

//定义方法,根据车型编号发送请求给服务器
        function update(id) {
            location.href="update.do?id="+id;
        }

?控制层中定义方法接收该请求,并将编号临时存储至session中,然后跳转至修改页面

//定义方法,接收编号
    @RequestMapping("update.do")
    public String update(@RequestParam int id, HttpSession session){
        //将用户要修改的车型信息的编号临时存储在session,因为session中的数据在不切换浏览器的情况下可以任意共享
        session.setAttribute("id",id);
        return "update.html";
    }

在web文件夹中新建update.html页面,在页面加载完毕后,自动发出ajax请求,要求服务器将要修改的车型数据信息发回修改页面并显示:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>修改车型信息</title>
    <style>
        table{
            width: 600px;
            height: 400px;
            padding: 10px;
            background-color:cornflowerblue ;
            border-width: 0px;
            border-radius: 6px;
            text-align: center;
            color: white;
            font-weight: bold;
        }
        #sub{
            background-color: darkcyan;
            color: white;
            font-weight: bold;
            border-width: 0px;
            border-radius: 6px;
            width: 200px;
            padding: 10px 20px;
        }
        #sub:hover{
            background-color:#648B87 ;
        }
    </style>
    <script src="js/jquery-3.2.1.min.js"></script>
    <script>
        //当页面加载完毕,自动触发ajax请求
        $(function () {
           $.ajax({
               url:"toUpdate.do",
               type:"GET",
               data:"",
               success:function (json) {
                    //{}
                   $("input[name='carName']").val(json.carName);
                   $("input[name='brandName']").val(json.brandName);
                   $("input[name='price']").val(json.price);
                   $("input[name='click']").val(json.click);
               },
               error:function () {
                   alert("连接失败");
               },
               dataType:"json"
           });
        });
    </script>
</head>
<body>
<div align="center">
    <form action="updateInfo.do" method="post">
        <table>
            <tr>
                <th colspan="2">修改品牌</th>
            </tr>
            <tr>
                <td>车型名称</td>
                <td><input type="text" name="carName" placeholder="请输入车型名称"></td>
            </tr>
            <tr>
                <td>品牌名称</td>
                <td><input type="text" name="brandName" placeholder="请输入品牌名称"></td>
            </tr>
            <tr>
                <td>官方价格</td>
                <td><input type="number" name="price" placeholder="请输入价格"></td>
            </tr>
            <tr>
                <td>点击量</td>
                <td><input type="number" name="click" placeholder="请输入点击量"></td>
            </tr>
            <tr>
                <td colspan="2"><input type="submit" id="sub" value="更新"></td>
            </tr>
        </table>
    </form>
</div>
</body>
</html>

控制器中定义方法,接收修改页面的请求,根据session中的编号作为条件查询该编号下的车型信息并转换成json格式发回修改页面显示在文本框中,供用户修改:

//定义方法,根据编号获得要修改的车型信息
    @RequestMapping("toUpdate.do")
    @ResponseBody
    public Object toUpdate(HttpSession session){
        int id= (int) session.getAttribute("id");
        //把车型编号作为查询条件,查询该编号的车型信息
        Map<String,Object> map=service.getInfoById(id);
        //{}
        return  map;
    }

业务逻辑层获得控制层的调用:

Map<String, Object> getInfoById(int id);
@Override
    public Map<String, Object> getInfoById(int id) {
        return dao.getInfoById(id);
    }

数据访问层执行查询sql语句:

@Select("select * from car where carId=#{id}")
    Map<String, Object> getInfoById(@Param("id") int id);

最后将结果发回修改页面,其效果如下:

当用户修改数据后,点击更新按钮将修改后的数据通过表单发送给控制器:

 //定义方法,接收页面发送过来的数据
    @RequestMapping("/updateInfo.do")
    public String updateInfo(@RequestParam String carName, @RequestParam String brandName, @RequestParam double price, @RequestParam int click, HttpSession session){
        Map<String,Object> map=new HashMap<>();
        map.put("carName",carName);
        map.put("brandName",brandName);
        map.put("price",price);
        map.put("click",click);
        int carId= (int) session.getAttribute("id");
        map.put("carId",carId);
        int i= service.updateCar(map);
        return "index.html";
    }

?并将封装好的数据递交给业务逻辑层执行:

 int updateCar(Map<String, Object> map);
 @Override
    public int updateCar(Map<String, Object> map) {
        return dao.updateCar(map);
    }

业务逻辑层将数据递交给dao层完成修改的sql语句

 @Update("update car set carName=#{carName},brandName=#{brandName},price=#{price},click=#{click} where carId=#{carId}")
    int updateCar(Map<String, Object> map);

并修改成功后跳转回首页,更新页面上的数据

总结

本文到这里就结束了,读者根据流程执行功能!!!

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-06-06 17:16:21  更:2022-06-06 17:17:09 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 9:02:16-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码