共计 5911 个字符,预计需要花费 15 分钟才能阅读完成。
1. 商品后盾治理
1.1 商品新增
1.1.1 页面的剖析
1.url 剖析
2. 参数剖析
3. 页面 JS 编辑
function submitForm(){
// 表单校验
if(!$('#itemAddForm').form('validate')){$.messager.alert('提醒','表单还未填写实现!');
return ;
}
// 转化价格单位,将元转化为分
//$("#price").val(); 取值 $("#price").val(100);
//eval() 专门做算数计算的 1+1 "1"+1
$("#itemAddForm [name=price]").val(eval($("#itemAddForm [name=priceView]").val()) * 100);
itemAddEditor.sync();// 将输出的内容同步到多行文本中
$.post("/item/save",$("#itemAddForm").serialize(), function(data){if(data.status == 200){$.messager.alert('提醒','新增商品胜利!');
}else{$.messager.alert("提醒","新增商品失败!");
}
});
}
<input id=”id” type=”text” name=”id” value=”123″/>
$(“input[name=’id’]”)
4. 属性选择器:
1.1. 封装 SysResult
阐明: 在 jt-common 中增加零碎返回值 vo 对象
package com.jt.vo;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.Accessors;
// 作用: 指定零碎的返回值 vo 对象, 与前端进行交互
@Data
@Accessors(chain = true)
@NoArgsConstructor
@AllArgsConstructor
public class SysResult {
private Integer status; //200 胜利 201 失败
private String msg; // 服务器返回的服务器信息
private Object date; // 服务器数据
//1. 编辑失败办法
public SysResult fail(){return new SysResult(201,"服务器解体了呀",null);
}
//2. 重载胜利的办法
public static SysResult success(){return new SysResult(200,"拜访胜利啦",null);
}
public static SysResult success(Object data){return new SysResult(200,"拜访胜利啦",data);
}
public static SysResult success(String msg,Object data){return new SysResult(200,msg,data);
}
}
1.1.3 编辑 ItemController
/**
* 业务需要:
* 实现商品入库操作.
* 注意事项:
* 1. 避免办法出错增加 try-catch
* 2. 新增商品的状态信息 为 1
* 3. 入库操作时 实现工夫的记录.
* 申请参数:
* 1.url 地址:/item/save
* 2. 申请参数: form 表单 对象接管
* 3. 返回值: 零碎级别的 VO 对象
*
* 常识温习:
* input name="age" value=18
*/
@RequestMapping("/save")
public SysResult saveItem(Item item){
try {itemService.saveItem(item);
return SysResult.success();}catch (Exception e){e.printStackTrace();
return SysResult.fail();}
}
1.1.4 编辑 ItemService
@Override
public void saveItem(Item item) {item.setStatus(1) // 默认是失常状态
.setCreated(new Date())
.setUpdated(item.getCreated());
itemMapper.insert(item);
}
1.2 全局异样解决机制阐明
阐明: 在 jt-common 中 增加全局解决异样机制
package com.jt.aop;
import com.jt.vo.SysResult;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.RestControllerAdvice;
@RestControllerAdvice // 定义全局异样解决
public class SystemException {
// 遇到运行时异样时办法执行.
@ExceptionHandler({RuntimeException.class})
public Object fail(Exception e){e.printStackTrace(); // 输入异样信息.
return SysResult.fail();}
}
1.3 主动填充性能
1.3.1 业务需要
例如更新工夫 / 创立工夫都须要更新相干数据, 是否将数据进行优化, 简化程序调用
1.3.2 编辑 BasePOJO 指定填充属性
1.3.2 编辑配置类
阐明: 在 jt-common 中 编辑配置类, 实现主动填充性能.
package com.jt.handler;
import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;
import java.util.Date;
@Component // 将对象交给 spring 容器治理
public class MyMetaObjectHandler implements MetaObjectHandler {
// 实现入库操作主动赋值
@Override
public void insertFill(MetaObject metaObject) {Date date = new Date();
this.setFieldValByName("created",date,metaObject);
this.setFieldValByName("updated",date,metaObject);
}
// 实现更新操作主动赋值
@Override
public void updateFill(MetaObject metaObject) {this.setFieldValByName("updated",new Date(),metaObject);
}
}
1.4 商品批改操作
1.4.1 页面剖析
{
text:'编辑',
iconCls:'icon-edit',
handler:function(){
// 获取用户选中的数据
var ids = getSelectionsIds();
if(ids.length == 0){$.messager.alert('提醒','必须抉择一个商品能力编辑!');
return ;
}
if(ids.indexOf(',') > 0){$.messager.alert('提醒','只能抉择一个商品!');
return ;
}
// 须要找到一个空的 div 之后展示窗口
$("#itemEditWindow").window({onLoad :function(){
// 回显数据
var data = $("#itemList").datagrid("getSelections")[0];
data.priceView = KindEditorUtil.formatPrice(data.price);
// 将 data 的数据回显到批改页面中.
$("#itemeEditForm").form("load",data);
.....
}
1.4.2 实现批改页面分类信息回显
常识回顾:
阐明: 能够通过商品分类 ID, 动静获取称申请门路装置图中标识
3. 编辑页面 JS
1.4.3 商品批改的 ajax
1.5 商品删除操作
/**
* 实现商品批改操作
* 1.url 地址: /item/update
* 2. 申请参数: form 表单提交
* 3. 返回值: SysResult 对象
*/
@RequestMapping("/update")
public SysResult updateItem(Item item){itemService.updateItem(item);
return SysResult.success();}
1.4.5 编辑 ItemService
// 个别更新操作都是依据主键更新
//Sql: update tb_item set titel=#{xxxx},xx,x,x,x,x, where id=#{xxx}
@Override
public void updateItem(Item item) {
// 依据对象中不为 null 的元素充当 set 条件
itemMapper.updateById(item);
}
1.5 商品删除操作
1.5.1 页面 url 提交
2. 参数提交
3. 页面 js 剖析
1.5.2 编辑 ItemController
/**
* 业务需要: 删除商品信息
* 1.url 地址: /item/delete
* 2. 参数: ids: 100,101,102 serlvet(request) 同名提交问题
* 3. 返回值: SysResult
* springMVC 规定: 如果传递的数据是由, 号分隔的字符串则能够应用数组接管
* */
@RequestMapping("/delete")
public SysResult deleteItems(Long... ids){
//1. 将 ids 字符串依照, 号拆分
itemService.deleteItems(ids);
return SysResult.success();}
1.5.3 编辑 ItemService
// 批量删除操作
@Override
public void deleteItems(Long[] ids) {//List<Long> longList = Arrays.asList(ids);
//itemMapper.deleteBatchIds(longList);
// 手动的删除数据
itemMapper.deleteItems(ids);
}
1.5.4 编辑 ItemMapper
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.jt.mapper.ItemMapper">
<!--
Mybatis 数据传参的原理:
规定: Mybatis 只能接管单值传参!!!
如果有多个数据须要传值, 则须要将多值封装为单值
形式:
1. 利用对象传参
2. 利用数组传参
3. 利用 Map 汇合传参
汇合的写法:
数据类型是数组 collection="array"
数据类型是 list 汇合 collection="list"
数据类型是 Map 汇合 collection="map 的 key"
ids=100,101,102
collection: 获取传递汇合的 key
open="汇合遍历前缀"
close="汇合遍历后缀"
separator="分隔符"
item="以后遍历的对象"
-->
<delete id="deleteItems" >
DELETE FROM tb_item WHERE id in (
<foreach collection="array" item="id" separator=",">
#{id}
</foreach>
)
</delete>
</mapper>
1.6 实现商品上架 / 下架操作
1.6.1 业务需要
阐明: 如果批改商品的状态信息, 上架 =1 下架 =2. 只须要批改数据记录即可.
url 剖析
http://calhost:8091/item/instock 下架操作 status=2
http://localhost:8091/item/reshelf 上架操作 status=1
需要: 是否利用一个办法实现上架 / 下架操作???
http://localhost:8091/item/updateStatus/2 下架操作 status=2
http://localhost:8091/item/updateStatus/1 上架操作 status=1
需要: 是否利用一个办法实现上架 / 下架操作?
1.6.2 批改页面 JS
阐明: 将页面上架 / 下架操作, 依照上述剖析进行批改.
1.6.3 编辑 ItemController
/**
* 业务: 实现商品的上架 / 下架
* url 地址: /item/updateStatus/2
* 参数: 状态码信息 /ids
* 返回值: SysResult 对象
* */
@RequestMapping("/updateStatus/{status}")
public SysResult updateStatus(@PathVariable Integer status,Long... ids){itemService.updateStatus(ids,status);
return SysResult.success();}
1.6.3 编辑 ItemService
// 作业:sql 手动实现
// 参数阐明: entity: 批改数据的值 updateWrapper
@Override
public void updateStatus(Long[] ids, Integer status) {Item item = new Item();
item.setStatus(status);
//where id in (1,2,3,4)
UpdateWrapper<Item> updateWrapper = new UpdateWrapper<>();
updateWrapper.in("id",Arrays.asList(ids));
itemMapper.update(item,updateWrapper);
}
正文完