本文共 6355 字,大约阅读时间需要 21 分钟。
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("提示","新增商品失败!"); } }); }
说明:在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@AllArgsConstructorpublic class SysResult { private Integer status; //200成功 201失败 private String msg; //服务器返回的提示信息 private Object data; //服务器数据 //1.编辑失败方法 public static 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. 防止方法出错添加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(); } }
@Override public void saveItem(Item item) { item.setStatus(1) //默认是正常状态 .setCreated(new Date()) .setUpdated(item.getCreated()); itemMapper.insert(item); }
说明:在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(); }}
例如更新时间/创建时间,每个业务操作时都需要更新相关数据,能否将数据进行优化,简化程序调用.
说明:在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); }}
{ 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); ..... }
知识回顾:
说明:可以通过商品分类Id,动态获取商品分类的名称.请求路径按照图中标识.3.编辑页面JS
/** * 实现商品修改操作 * 1.url地址: /item/update * 2.请求参数: form表单提交 * 3.返回值: SysResult对象 */ @RequestMapping("/update") public SysResult updateItem(Item item){ itemService.updateItem(item); return SysResult.success(); }
//一般更新操作都是根据主键更新 //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); }
2.参数提交
3. 页面JS分析
/** * 业务需求: 删除商品信息 * 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(); }
//批量删除操作 @Override public void deleteItems(Long[] ids) { //ListlongList = Arrays.asList(ids); //itemMapper.deleteBatchIds(longList); //手动的删除数据 itemMapper.deleteItems(ids); }
DELETE FROM tb_item WHERE id in ( #{id} )
说明:如果修改商品的状态信息. 上架=1 下架=2. 只需要修改数据库记录即可.
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说明:将页面上架/下架操作,按照上述分析进行修改.
/** * 业务: 实现商品的上架/下架 * url地址: /item/updateStatus/2 * 参数: 状态码信息/ids * 返回值: SysResult对象 * */ @RequestMapping("/updateStatus/{status}") public SysResult updateStatus(@PathVariable Integer status,Long... ids){ itemService.updateStatus(ids,status); return SysResult.success(); }
//作业: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- updateWrapper = new UpdateWrapper<>(); updateWrapper.in("id",Arrays.asList(ids)); itemMapper.update(item,updateWrapper); }
转载地址:http://cvsli.baihongyu.com/