概念
本文完成添加及修改车型信息的功能。
添加功能实现
在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);
并修改成功后跳转回首页,更新页面上的数据
总结
本文到这里就结束了,读者根据流程执行功能!!!