一、 商品新增

1.1 页面分析

1.url分析
06-京淘项目CURD - 图1
2.参数分析
06-京淘项目CURD - 图2

  1. 页面JS编辑

    1. function submitForm(){
    2. //表单校验
    3. if(!$('#itemAddForm').form('validate')){
    4. $.messager.alert('提示','表单还未填写完成!');
    5. return ;
    6. }
    7. //转化价格单位,将元转化为分
    8. //$("#price").val(); 取值 $("#price").val(100);
    9. //eval() 专门做算数计算的 1+1 "1"+1
    10. $("#itemAddForm [name=price]").val(eval($("#itemAddForm [name=priceView]").val()) * 100);
    11. itemAddEditor.sync();//将输入的内容同步到多行文本中
    12. $.post("/item/save",$("#itemAddForm").serialize(), function(data){
    13. if(data.status == 200){
    14. $.messager.alert('提示','新增商品成功!');
    15. }else{
    16. $.messager.alert("提示","新增商品失败!");
    17. }
    18. });
    19. }

    1.2 封装SysResult

    说明:在jt-common中添加系统返回值VO对象

    1. package com.jt.vo;
    2. import lombok.AllArgsConstructor;
    3. import lombok.Data;
    4. import lombok.NoArgsConstructor;
    5. import lombok.experimental.Accessors;
    6. //作用: 指定系统返回值vo对象,与前端进行交互
    7. @Data
    8. @Accessors(chain = true)
    9. @NoArgsConstructor
    10. @AllArgsConstructor
    11. public class SysResult {
    12. private Integer status; //200成功 201失败
    13. private String msg; //服务器返回的提示信息
    14. private Object data; //服务器数据
    15. //1.编辑失败方法
    16. public static SysResult fail(){
    17. return new SysResult(201,"服务器调用失败",null);
    18. }
    19. //2.重载成功方法
    20. public static SysResult success(){
    21. return new SysResult(200,"服务器执行成功",null);
    22. }
    23. public static SysResult success(Object data){
    24. return new SysResult(200,"服务器执行成功",data);
    25. }
    26. public static SysResult success(String msg,Object data){
    27. return new SysResult(200,msg,data);
    28. }
    29. }

    1.3 编辑ItemController

    1. /**
    2. * 业务需求:
    3. * 完成商品入库操作.
    4. * 注意事项:
    5. * 1. 防止方法出错添加try-catch
    6. * 2. 新增商品的状态信息 为1
    7. * 3. 入库操作时 完成时间的记录.
    8. * 请求参数:
    9. * 1.url地址:/item/save
    10. * 2.请求参数: form表单 对象接收
    11. * 3.返回值: 系统级别的VO对象
    12. *
    13. * 知识复习:
    14. * input name="age" value=18
    15. */
    16. @RequestMapping("/save")
    17. public SysResult saveItem(Item item){
    18. try {
    19. itemService.saveItem(item);
    20. return SysResult.success();
    21. }catch (Exception e){
    22. e.printStackTrace();
    23. return SysResult.fail();
    24. }
    25. }

    1.4 编辑ItemService

    1. @Override
    2. public void saveItem(Item item) {
    3. item.setStatus(1) //默认是正常状态
    4. .setCreated(new Date())
    5. .setUpdated(item.getCreated());
    6. itemMapper.insert(item);
    7. }

    二、全局异常处理机制说明

    说明:在jt-common中 添加全局异常处理机制.

    1. package com.jt.aop;
    2. import com.jt.vo.SysResult;
    3. import org.springframework.web.bind.annotation.ExceptionHandler;
    4. import org.springframework.web.bind.annotation.RestControllerAdvice;
    5. @RestControllerAdvice //定义全局异常处理
    6. public class SystemException {
    7. //遇到运行时异常时方法执行.
    8. @ExceptionHandler({RuntimeException.class})
    9. public Object fail(Exception e){
    10. e.printStackTrace(); //输出异常信息.
    11. return SysResult.fail();
    12. }
    13. }

    三、 自动填充功能

    3.1 业务需求

    例如更新时间/创建时间,每个业务操作时都需要更新相关数据,能否将数据进行优化,简化程序调用.
    06-京淘项目CURD - 图3

    3.2 编辑BasePOJO 指定填充属性

    06-京淘项目CURD - 图4

    3.3 编辑配置类

    说明:在jt-common中 编辑配置类,实现自动填充功能.

    1. package com.jt.handler;
    2. import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
    3. import org.apache.ibatis.reflection.MetaObject;
    4. import org.springframework.stereotype.Component;
    5. import java.util.Date;
    6. @Component //将对象交给spring容器管理
    7. public class MyMetaObjectHandler implements MetaObjectHandler {
    8. //完成入库操作自动赋值
    9. @Override
    10. public void insertFill(MetaObject metaObject) {
    11. Date date = new Date();
    12. this.setFieldValByName("created",date,metaObject);
    13. this.setFieldValByName("updated",date,metaObject);
    14. }
    15. //完成更新操作自动赋值
    16. @Override
    17. public void updateFill(MetaObject metaObject) {
    18. this.setFieldValByName("updated",new Date(),metaObject);
    19. }
    20. }

    四、 商品修改操作

    4.1 页面分析

    1. {
    2. text:'编辑',
    3. iconCls:'icon-edit',
    4. handler:function(){
    5. //获取用户选中的数据
    6. var ids = getSelectionsIds();
    7. if(ids.length == 0){
    8. $.messager.alert('提示','必须选择一个商品才能编辑!');
    9. return ;
    10. }
    11. if(ids.indexOf(',') > 0){
    12. $.messager.alert('提示','只能选择一个商品!');
    13. return ;
    14. }
    15. //需要找到一个空的div之后展现窗口
    16. $("#itemEditWindow").window({
    17. onLoad :function(){
    18. //回显数据
    19. var data = $("#itemList").datagrid("getSelections")[0];
    20. data.priceView = KindEditorUtil.formatPrice(data.price);
    21. //将data的数据回显到修改页面中.
    22. $("#itemeEditForm").form("load",data);
    23. .....
    24. }

    4.2 实现修改页面分类信息回显

    06-京淘项目CURD - 图5
    知识回顾:
    说明:可以通过商品分类Id,动态获取商品分类的名称.请求路径按照图中标识.06-京淘项目CURD - 图6
    3.编辑页面JS
    06-京淘项目CURD - 图7

    4.3 商品修改的ajax

    06-京淘项目CURD - 图8

    4.4 编辑ItemController

    1. /**
    2. * 实现商品修改操作
    3. * 1.url地址: /item/update
    4. * 2.请求参数: form表单提交
    5. * 3.返回值: SysResult对象
    6. */
    7. @RequestMapping("/update")
    8. public SysResult updateItem(Item item){
    9. itemService.updateItem(item);
    10. return SysResult.success();
    11. }

    4.5 编辑ItemService

    1. //一般更新操作都是根据主键更新
    2. //Sql: update tb_item set titel=#{xxxx},xx,x,x,x,x, where id=#{xxx}
    3. @Override
    4. public void updateItem(Item item) {
    5. //根据对象中不为null的元素充当set条件
    6. itemMapper.updateById(item);
    7. }

    五、 商品删除操作

    5.1 页面url分析

    06-京淘项目CURD - 图9
    2.参数提交
    06-京淘项目CURD - 图10
    3. 页面JS分析
    06-京淘项目CURD - 图11

    5.2 编辑ItemController

    1. /**
    2. * 业务需求: 删除商品信息
    3. * 1.url地址: /item/delete
    4. * 2.参数: ids: 100,101,102 serlvet(request) 同名提交问题
    5. * 3.返回值: SysResult
    6. * springMVC规则: 如果传递的数据是由,号分隔的字符串则可以使用数组接收
    7. * */
    8. @RequestMapping("/delete")
    9. public SysResult deleteItems(Long... ids){
    10. //1.将ids字符串按照,号拆分
    11. itemService.deleteItems(ids);
    12. return SysResult.success();
    13. }

    5.3 编辑ItemService

    1. //批量删除操作
    2. @Override
    3. public void deleteItems(Long[] ids) {
    4. //List<Long> longList = Arrays.asList(ids);
    5. //itemMapper.deleteBatchIds(longList);
    6. //手动的删除数据
    7. itemMapper.deleteItems(ids);
    8. }

    5.4 编辑ItemMapper

    06-京淘项目CURD - 图12

    1. <?xml version="1.0" encoding="UTF-8" ?>
    2. <!DOCTYPE mapper
    3. PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
    4. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
    5. <mapper namespace="com.jt.mapper.ItemMapper">
    6. <!--
    7. Mybatis数据传参的原理:
    8. 规则: Mybatis只能接收单值传参!!!
    9. 如果有多个数据需要传值,则需要将多值封装为单值
    10. 方式:
    11. 1.利用对象传参
    12. 2.利用数组传参
    13. 3.利用Map集合传参
    14. 集合的写法:
    15. 数据类型是数组 collection="array"
    16. 数据类型是list集合 collection="list"
    17. 数据类型是Map集合 collection="map的key"
    18. ids=100,101,102
    19. collection: 获取传递集合的key
    20. open="集合遍历前缀"
    21. close="集合遍历后缀"
    22. separator="分隔符"
    23. item="当前遍历的对象"
    24. -->
    25. <delete id="deleteItems" >
    26. DELETE FROM tb_item WHERE id in (
    27. <foreach collection="array" item="id" separator=",">
    28. #{id}
    29. </foreach>
    30. )
    31. </delete>
    32. </mapper>

    六、现商品上架/下架操作

    6.1 业务需求

    说明:如果修改商品的状态信息. 上架=1 下架=2. 只需要修改数据库记录即可.
    06-京淘项目CURD - 图13
    url分析:
    http://localhost: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

    6.2 修改页面JS

    说明:将页面上架/下架操作,按照上述分析进行修改.
    06-京淘项目CURD - 图14

    6.3 编辑ItemController

    1. /**
    2. * 业务: 实现商品的上架/下架
    3. * url地址: /item/updateStatus/2
    4. * 参数: 状态码信息/ids
    5. * 返回值: SysResult对象
    6. * */
    7. @RequestMapping("/updateStatus/{status}")
    8. public SysResult updateStatus(@PathVariable Integer status,Long... ids){
    9. itemService.updateStatus(ids,status);
    10. return SysResult.success();
    11. }

    6.4 编辑ItemService

    1. //作业:sql手动完成
    2. //参数说明: entity:修改数据的值 updateWrapper
    3. @Override
    4. public void updateStatus(Long[] ids, Integer status) {
    5. Item item = new Item();
    6. item.setStatus(status);
    7. //where id in (1,2,3,4)
    8. UpdateWrapper<Item> updateWrapper = new UpdateWrapper<>();
    9. updateWrapper.in("id",Arrays.asList(ids));
    10. itemMapper.update(item,updateWrapper);
    11. }

    七、总结

    本节主要是实现增删改查四个基本业务,根据前端的业务逻辑,从前端页面获取到数据修改到数据库的内容。