商品规格管理的实现——淘淘商城(十二)

创建规格模板

分析

  • item-param-list中新增规格参数指向的url为/item-param-add,所以在 item-param-add.jsp中添加规格模板。
    4.itemParamToolBar.png
  • 通过common.js中的函数初始化类目选择器。如果查询到商品规格存在,则提示重复。
    4.initItemParam.png
  • 底部js中通过ajax存储规格参数,创建规格模板。
    4.itemParamjson.png
    4.saveItemParam.png

需求

  • 查询规格模板:
    • 请求url:/item/param/query/itemcatid/{itemCatId}
    • 请求参数: 商品分类id,url中获得。
    • 响应参数:TaoTaoResult。
  • 存储规格模板:
    • 请求url:/item/param/save/{cid}
    • 请求参数:
      • 商品分类id,url中的cid。
      • 商品参数模板的json字符串,post的实体paramData。
    • 响应参数:TaoTaoResult。

查询模板

Service层
  • 创建ItemParamService和对应实现类。
  • 根据商品分类id在tb_item_param表中查询对应的模板,在taotaoResult的data中设置查找到的模板或者置为Null。
@Service
public class ItemParamServiceImpl implements ItemParamService {

    @Autowired
    private TbItemParamMapper itemParamMapper;

    @Override
    public TaotaoResult getItemParamByCid(long cid) {
        //设置查询条件,满足cid的商品目录
        TbItemParamExample example = new TbItemParamExample();
        Criteria criteria = example.createCriteria();
        criteria.andItemCatIdEqualTo(cid);

        //执行查询,注意使用withBLOBs,否则查询结果不会附带大文本。
        List<TbItemParam> list = itemParamMapper.selectByExampleWithBLOBs(example);
        if (list != null && list.size() > 0) {
            return TaotaoResult.ok(list.get(0));
        }

        return TaotaoResult.ok();

    }
}
Controller层
  • 创建ItemParamController,接收商品分类id,返回包含查询模板结果的TaoTaoResult的json。
@Controller
@RequestMapping("/item/param")
public class ItemParamController {

    @Autowired
    private ItemParamService itemParamService;

    @RequestMapping("/query/itemcatid/{itemCatId}")
    @ResponseBody
    public TaotaoResult getItemParamByCid(@PathVariable Long itemCatId) {
        TaotaoResult result = itemParamService.getItemParamByCid(itemCatId);
        return result;
    }
}

创建模板

Service层
  • ItemParamServiceImpl中,接收模板对象,补全参数之后插入数据库,返回TaotaoResult。
    public TaotaoResult insertItemParam(TbItemParam itemParam) {
        //补全创建和更新时间
        itemParam.setCreated(new Date());
        itemParam.setUpdated(new Date());

        itemParamMapper.insert(itemParam);

        return TaotaoResult.ok();
    }
Controller层
  • ItemParamController中,接收商品分类id和模板参数json,装入TbItemParam类中调用service接口,返回TaotaoResult的json。
    @RequestMapping("/save/{cid}")
    @ResponseBody
    public TaotaoResult insertItemParam(@PathVariable Long cid, String paramData) {
        TbItemParam itemParam = new TbItemParam();
        itemParam.setItemCatId(cid);
        itemParam.setParamData(paramData);

        TaotaoResult result = itemParamService.insertItemParam(itemParam);
        return result;
    }

根据规格模板生成表单

分析

  • item-add.jsp中通过调用changeItemParam在选择商品类别之后生成规格信息表单。data.data.paramData为模板的json。
    4.createItemParamForm.png
    4.changeItemParam.png
  • 生成的表单如下:
    4.showItemParam.png

需求

  • 根据商品类别id查询模板的接口已经实现。

保存商品规格参数

分析

  • item-add.jsp中将规格参数转化为json字符串,放入隐藏input表单itemParams中,通过ajax保存包括商品规格参数在内的商品信息。
    4.postParams.png
    4.nameItemParam.png

需求

  • 请求url:/item/save
  • 请求参数:
    • 商品信息(TbItem,不包括商品规格)。
    • 商品描述。
    • 商品规格。
  • 响应参数:TaotaoResult。
  • 需要修改添加商品的接口。

Service层

  • 修改ItemService和实现类的addItem方法,增加itemParamItem参数,并补全规格信息,将规格插入数据库,返回taotaoResult。
    public TaotaoResult addItem(TbItem item, TbItemDesc itemDesc, TbItemParamItem itemParamItem) {
        try {
            //生成商品id,使用时间+随机数策略生成
            Long itemId = IDUtils.genItemId();

            //补全商品信息
            item.setId(itemId);
            item.setStatus((byte) 1);
            item.setCreated(new Date());
            item.setUpdated(new Date());
            //把数据插入到商品表
            itemMapper.insert(item);

            //补全商品描述信息
            itemDesc.setItemId(itemId);
            itemDesc.setCreated(new Date());
            itemDesc.setUpdated(new Date());
            //把数据插入到商品描述表
            itemDescMapper.insert(itemDesc);

            //补全商品规格参数
            itemParamItem.setItemId(itemId);
            itemParamItem.setCreated(new Date());
            itemParamItem.setUpdated(new Date());
            //插入商品规格到商品规格表
            itemParamItemMapper.insert(itemParamItem);
        } catch (Exception e) {
            e.printStackTrace();
            return TaotaoResult.build(500, ExceptionUtil.getStackTrace(e));
        }

        return TaotaoResult.ok();

    }

Controller层

  • ItemController中addItem方法增加itemParams入参,组织itemParamItem,调用对应service方法,返回TaotaoResult的json。
    @RequestMapping(value = "/save", method = RequestMethod.POST)
    @ResponseBody
    public TaotaoResult addItem(TbItem item, String desc, String itemParams) {
        TbItemDesc itemDesc = new TbItemDesc();
        itemDesc.setItemDesc(desc);
        TbItemParamItem itemParamItem = new TbItemParamItem();
        itemParamItem.setParamData(itemParams);

        TaotaoResult result = itemService.addItem(item, itemDesc, itemParamItem);
        return result;
    }

展示规格参数

分析

  • item-param-list.jsp中利用data-options控件显示规格参数。
    4.itemparamlist.png

需求

  • 请求url:/item/param/list?page=xxx&rows=yyy。
  • 请求参数:分页参数page和rows。
  • 响应参数:EasyUIDataGridResult,list中的对象包含的属性为TbItemParam的变量和itemCatName。

Service层

  • taotao-manager-pojo中新建ItemParamWithName,满足data-options控件需要的变量。
public class ItemParamWithName extends TbItemParam {

    private String itemCatName;

    public ItemParamWithName(TbItemParam itemParam, String itemCatName) {
        this.itemCatName = itemCatName;
        this.setUpdated(itemParam.getUpdated());
        this.setCreated(itemParam.getCreated());
        this.setId(itemParam.getId());
        this.setItemCatId(itemParam.getItemCatId());
        this.setParamData(itemParam.getParamData());
    }

    public String getItemCatName() {
        return itemCatName;
    }

    public void setItemCatName(String itemCatName) {
        this.itemCatName = itemCatName;
    }
}
  • ItemParamService和实现类中根据分页参数查询规格参数列表,在逐个查询规格对应的名称之后,封装到ItemParamWithName类的列表中,最后封装到EasyUIDataGridResult中。
    public EasyUIDataGridResult getItemParamList(int page, int rows) {
        //分页处理
        PageHelper.startPage(page, rows);
        List<TbItemParam> paramList = itemParamMapper.selectByExampleWithBLOBs(new TbItemParamExample());

        //查询规格对应的名称并封装
        List<ItemParamWithName> paramWithNameList = new ArrayList<>(paramList.size());
        for (TbItemParam itemParam : paramList) {
            String name = getItemCatName(itemParam.getItemCatId());
            paramWithNameList.add(new ItemParamWithName(itemParam, name));
        }

        //总记录条数
        PageInfo<TbItemParam> pageInfo = new PageInfo<>(paramList);
        long total = pageInfo.getTotal();

        EasyUIDataGridResult result = new EasyUIDataGridResult();
        result.setTotal(total);
        result.setRows(paramWithNameList);

        return result;

    }
    private String getItemCatName(long itemCatId) {
        TbItemCatExample example = new TbItemCatExample();
        TbItemCatExample.Criteria criteria = example.createCriteria();
        criteria.andIdEqualTo(itemCatId);

        List<TbItemCat> list = itemCatMapper.selectByExample(example);
        if (list != null && !list.isEmpty()) {
            return list.get(0).getName();
        }
        return null;
    }

Controller层

  • 根据分页参数调用返回查询规格参数列表的service方法,返回EasyUIDataGridResult的json。
    @RequestMapping("/list")
    @ResponseBody
    public EasyUIDataGridResult getItemList(Integer page, Integer rows) {
        return itemParamService.getItemParamList(page, rows);
    }
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值