|
|
|
|
# 规格参数
|
|
|
|
|
|
|
|
|
|
## 1.基础页面
|
|
|
|
|
|
|
|
|
|
  基础页面和属性组的页面非常类似,所以我们先创建了该页面,直接使用
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/fb2f9/fb2f9b9b9620c21a15c9d606cd77e8cd90f991c9" alt="image.png"
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/2e4e5/2e4e52fca4bc81ede7b41798711d8d1a2ee5f5ac" alt="image.png"
|
|
|
|
|
|
|
|
|
|
## 2.添加规格参数
|
|
|
|
|
|
|
|
|
|
  规格数据需要绑定对应的属性组,所以我们在后台通过VO对象来接收信息
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/196ef/196ef2d7732d077b1f203f976a47359c2e32738a" alt="image.png"
|
|
|
|
|
|
|
|
|
|
在后端处理添加的逻辑就需要调整
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/4fd4e/4fd4e134128abc2816da2c916c7f9d9a801334cf" alt="image.png"
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/de9c7/de9c768aff077b4f7035b1d2bd7d3d6e28249fa4" alt="image.png"
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/fcae5/fcae5036e0d711aec2feb1bc8e97d8faa6becd82" alt="image.png"
|
|
|
|
|
|
|
|
|
|
保存成功,后台可以看到相关的信息
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/9a19b/9a19b1ce38e9b52f784df5b98ba0ecedf1230563" alt="image.png"
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/47c7e/47c7eb45f0a4e70207570c54a1cf69b69dbb98f6" alt="image.png"
|
|
|
|
|
|
|
|
|
|
## 3.查询规格参数
|
|
|
|
|
|
|
|
|
|
  我们需要在后台添加一个查询规格参数的接口方法。
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/69e98/69e98b7ea1892fd9038a8f3b7a39a99f7f7220e9" alt="image.png"
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/b8020/b80204933348ca0016730af4062d56cb4e75d5a1" alt="image.png"
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/ac969/ac969e89863d7e54872cfd7bb7b546b233929d4a" alt="image.png"
|
|
|
|
|
|
|
|
|
|
## 4.展示对应信息
|
|
|
|
|
|
|
|
|
|
  上面的规格数据对应的所属分类和所属属性组名没有很好的展示,这时我们可以对应的查询处理。
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/5fc55/5fc55e27c1a1308a1d5d79919ffac2597720bb81" alt="image.png"
|
|
|
|
|
|
|
|
|
|
后台代码处理
|
|
|
|
|
|
|
|
|
|
```java
|
|
|
|
|
@Override
|
|
|
|
|
public PageUtils queryBasePage(Map<String, Object> params, Long catelogId) {
|
|
|
|
|
QueryWrapper<AttrEntity> wrapper = new QueryWrapper<>();
|
|
|
|
|
// 1.根据类别编号查询
|
|
|
|
|
if(catelogId != 0 ){
|
|
|
|
|
wrapper.eq("catelog_id",catelogId);
|
|
|
|
|
}
|
|
|
|
|
// 2.根据key 模糊查询
|
|
|
|
|
String key = (String) params.get("key");
|
|
|
|
|
if(!StringUtils.isEmpty(key)){
|
|
|
|
|
wrapper.and((w)->{
|
|
|
|
|
w.eq("attr_id",key).or().like("attr_name",key);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
// 3.分页查询
|
|
|
|
|
IPage<AttrEntity> page = this.page(
|
|
|
|
|
new Query<AttrEntity>().getPage(params),
|
|
|
|
|
wrapper
|
|
|
|
|
);
|
|
|
|
|
PageUtils pageUtils = new PageUtils(page);
|
|
|
|
|
// 4. 关联的我们需要查询出类别名称和属性组的名称
|
|
|
|
|
List<AttrEntity> records = page.getRecords();
|
|
|
|
|
List<AttrResponseVo> list = records.stream().map((attrEntity) -> {
|
|
|
|
|
AttrResponseVo responseVo = new AttrResponseVo();
|
|
|
|
|
BeanUtils.copyProperties(attrEntity, responseVo);
|
|
|
|
|
// 查询每一条结果对应的 类别名称和属性组的名称
|
|
|
|
|
CategoryEntity categoryEntity = categoryService.getById(attrEntity.getCatelogId());
|
|
|
|
|
if (categoryEntity != null) {
|
|
|
|
|
responseVo.setCatelogName(categoryEntity.getName());
|
|
|
|
|
}
|
|
|
|
|
// 设置属性组的名称
|
|
|
|
|
AttrAttrgroupRelationEntity entity = new AttrAttrgroupRelationEntity();
|
|
|
|
|
entity.setAttrId(attrEntity.getAttrId());
|
|
|
|
|
// 去关联表中找到对应的属性组ID
|
|
|
|
|
//attrAttrgroupRelationService.query(new QueryWrapper<AttrAttrgroupRelationEntity>().eq("attr_id",attrEntity.getAttrId()));
|
|
|
|
|
AttrAttrgroupRelationEntity attrAttrgroupRelationEntity = attrAttrgroupRelationDao
|
|
|
|
|
.selectOne(new QueryWrapper<AttrAttrgroupRelationEntity>().eq("attr_id", attrEntity.getAttrId()));
|
|
|
|
|
if (attrAttrgroupRelationEntity != null && attrAttrgroupRelationEntity.getAttrGroupId() != null) {
|
|
|
|
|
// 获取到属性组的ID,然后根据属性组的ID我们来查询属性组的名称
|
|
|
|
|
AttrGroupEntity attrGroupEntity = attrGroupService.getById(attrAttrgroupRelationEntity.getAttrGroupId());
|
|
|
|
|
responseVo.setGroupName(attrGroupEntity.getAttrGroupName());
|
|
|
|
|
}
|
|
|
|
|
return responseVo;
|
|
|
|
|
}).collect(Collectors.toList());
|
|
|
|
|
pageUtils.setList(list);
|
|
|
|
|
return pageUtils;
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/0b656/0b6569a33511bd67624f6557418fdaec1c989837" alt="image.png"
|
|
|
|
|
|
|
|
|
|
## 5.更新数据
|
|
|
|
|
|
|
|
|
|
  在规格参数修改中默认会回写基础的信息,但是对应的类别和属性组的信息不会回写。
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/f9c0d/f9c0deea1b5a84b8f8c994f0e658135eee645ae6" alt="image.png"
|
|
|
|
|
|
|
|
|
|
这时我们需要更新后台的获取更新数据的方法
|
|
|
|
|
|
|
|
|
|
```java
|
|
|
|
|
/**
|
|
|
|
|
* 根据规格参数ID查询对应的详细信息
|
|
|
|
|
* 1.规格参数的具体信息
|
|
|
|
|
* 2.关联的属性组信息
|
|
|
|
|
* 3.关联的类别信息
|
|
|
|
|
* @param attrId
|
|
|
|
|
* @return
|
|
|
|
|
*/
|
|
|
|
|
@Override
|
|
|
|
|
public AttrResponseVo getAttrInfo(Long attrId) {
|
|
|
|
|
// 声明返回的对象
|
|
|
|
|
AttrResponseVo responseVo = new AttrResponseVo();
|
|
|
|
|
// 1.根据ID查询规格参数的基本信息
|
|
|
|
|
AttrEntity attrEntity = this.getById(attrId);
|
|
|
|
|
BeanUtils.copyProperties(attrEntity,responseVo);
|
|
|
|
|
// 2.查询关联的属性组信息 中间表
|
|
|
|
|
AttrAttrgroupRelationEntity relationEntity = attrAttrgroupRelationDao.selectOne(new QueryWrapper<AttrAttrgroupRelationEntity>().eq("attr_id", attrId));
|
|
|
|
|
if(relationEntity != null){
|
|
|
|
|
AttrGroupEntity attrGroupEntity = attrGroupService.getById(relationEntity.getAttrGroupId());
|
|
|
|
|
responseVo.setAttrGroupId(attrGroupEntity.getAttrGroupId());
|
|
|
|
|
if(attrGroupEntity != null){
|
|
|
|
|
responseVo.setGroupName(attrGroupEntity.getAttrGroupName());
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
// 3.查询关联的类别信息
|
|
|
|
|
Long catelogId = attrEntity.getCatelogId();
|
|
|
|
|
Long[] catelogPath = categoryService.findCatelogPath(catelogId);
|
|
|
|
|
responseVo.setCatelogPath(catelogPath);
|
|
|
|
|
|
|
|
|
|
CategoryEntity categoryEntity = categoryService.getById(catelogId);
|
|
|
|
|
if(categoryEntity!=null){
|
|
|
|
|
responseVo.setCatelogName(categoryEntity.getName());
|
|
|
|
|
}
|
|
|
|
|
return responseVo;
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/cdd04/cdd04d2c22b0ae1cb340fc61947fe6045a2f4a00" alt="image.png"
|
|
|
|
|
|
|
|
|
|
然后就是提交更新数据的时候,默认只会更新主表的数据,这时我们还需要调整逻辑来更新管理的属性组的数据。
|
|
|
|
|
|
|
|
|
|
```java
|
|
|
|
|
@Transactional
|
|
|
|
|
@Override
|
|
|
|
|
public void updateBaseAttr(AttrVO attr) {
|
|
|
|
|
AttrEntity entity = new AttrEntity();
|
|
|
|
|
BeanUtils.copyProperties(attr,entity);
|
|
|
|
|
// 1.更新基本数据
|
|
|
|
|
this.updateById(entity);
|
|
|
|
|
// 2.修改分组关联的关系
|
|
|
|
|
AttrAttrgroupRelationEntity relationEntity = new AttrAttrgroupRelationEntity();
|
|
|
|
|
relationEntity.setAttrId(entity.getAttrId());
|
|
|
|
|
relationEntity.setAttrGroupId(attr.getAttrGroupId());
|
|
|
|
|
// 判断是否存在对应的数据
|
|
|
|
|
Integer count = attrAttrgroupRelationDao.selectCount(new QueryWrapper<AttrAttrgroupRelationEntity>().eq("attr_id",attr.getAttrId()));
|
|
|
|
|
if(count > 0){
|
|
|
|
|
// 说明有记录,直接更新
|
|
|
|
|
attrAttrgroupRelationDao.update(relationEntity,new UpdateWrapper<AttrAttrgroupRelationEntity>().eq("attr_id",attr.getAttrId()));
|
|
|
|
|
}else{
|
|
|
|
|
// 说明没有记录,直接插入
|
|
|
|
|
attrAttrgroupRelationDao.insert(relationEntity);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
# 销售属性
|
|
|
|
|
|
|
|
|
|
## 1.销售属性展示
|
|
|
|
|
|
|
|
|
|
  和基本属性的内容是一致的,所以将基本属性的页面作为一个子组件引用,然后通过传值来区别
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/83d5f/83d5f9efe0fa21970eaf18b5cfaad9f775afeb9f" alt="image.png"
|