编辑商品按钮显示商品对应数据
创始人
2025-05-28 20:42:21
0
  1. 同用户管理,权限管理等之前各个模块的编辑功能不同,因为商品具有很多可编辑的选项,所以选择像添加商品一样,单独放在一个组件中Edit.vue 。
  2. 不过相比于添加商品,还需要传递一下这个商品的id值
  3. 布局与添加商品一致(下文省略解释布局),只是需要发送请求,将后台返回的数据渲染到组件中

初步设置
设置路由规则
传递商品id到Edit.vue
router/index.js中:

 { path: '/goods/edit/:id', component: Edit }
1
Edit.vue中:

 data () {
    return {
      // 传递过来的 商品id
      id: this.$route.params.id
    }
  }
List.vue中:

 // 点击编辑按钮,跳转到编辑页面
    editById (id) {
      this.$router.push('/goods/edit/' + id)
    }
2. 获取数据
1. 查询商品信息
async getGoodsInfo () {
      const { data: res } = await this.$http.get('goods/' + this.id)

      if (res.meta.status !== 200) {
        return this.$message.error('获取商品信息失败!')
      }
      this.editForm = res.data
      this.$message.success('获取商品信息成功!')
    }
2. 获取商品分类数据
// 获取所有商品分类数据
    async getCateList () {
      const { data: res } = await this.$http.get('categories')
      if (res.meta.status !== 200) {
        return this.$message.error('获取商品分类数据失败!')
      }
      this.cateList = res.data
    }
3. 获取商品参数列表和静态属性
// 当切换tab页签时触发的函数
    async tabClicked () {
      // console.log(this.activeIndex)
      if (this.activeIndex === '1') {
        // 访问的是 动态参数面板
        const { data: res } = await this.$http.get(`categories/${this.cateId}/attributes`,
          {
            params: {
              sel: 'many'
            }
          })

        if (res.meta.status !== 200) {
          return this.$message.error('获取动态参数列表失败!')
        }

        console.log(res.data)

        res.data.forEach(item => {
          item.attr_vals =
          item.attr_vals.length === 0 ? [] : item.attr_vals.split(' ')
        })
        this.manyTableData = res.data
      } else if (this.activeIndex === '2') {
        // 访问的是静态属性面板
        const { data: res } = await this.$http.get(`categories/${this.cateId}/attributes`,
          {
            params: {
              sel: 'only'
            }
          })
        if (res.meta.status !== 200) {
          return this.$message.error('获取静态属性列表失败!')
        }

        console.log(res.data)

        this.onlyTableData = res.data
      }
    }
3. 关于数据和图片的回显
1. 级联选择器数据回显
在getGoodsInfo ()这个函数中加入以下代码:

// 设置级联选择器绑定值
      const tempList = res.data.goods_cat.split(',') // 这一步只是转化成了['1','3','6']
      //每个数组成员都是字符,而不是数字
      // 这里必须重新赋值为空数组,再赋值,否则v-model不能实现默认值回显
      this.editForm.goods_cat = []
      tempList.forEach(item => {
      // item - 0是把数据类型转换为数字,以与cateList 数据类型一致,否则不能正确回显默认值
        this.editForm.goods_cat.push(item - 0)
      })
功能实现:

2. 点击编辑后图片回显
查询文档得知有一个属性file-list:


则进行绑定:

 
     
            :action="uploadURL"
      :on-preview="handlePreview"
      :on-remove="handleRemove"
      list-type="picture"
      :headers="headerObj"
      :file-list="uploadedList"
      :on-success="handleSuccess">
      点击上传
     
   

最后,在getGoodsInfo ()这个函数中,循环editForm.pics中的每一项,把带有name和url属性的对象push到data节点下的picList:

// 将已上传的图片放入列表
this.editForm.pics.forEach(item => {
        const obj =
      {
        name: item.pics_id + '.jpg',
        url: item.pics_sma_url
      }
        this.uploadedList.push(obj)
      })
查阅了官方文档发现,有name属性,才能够点击到图片名字,从而有预览效果

4. 编辑完成后点击提交按钮
文档里面是不需要传递分类id的,但是通过请求得到的信息“该商品未设置分类”,推测需要传递商品的分类id,并且类型是一个包括每一级分类,且用逗号“,”分割的字符串

// 点击修改商品按钮
    edit () {
      this.$refs.editFormRef.validate(async valid => {
        if (!valid) {
          return this.$message.error('请填写必要的表单项!')
        }
        const form = _.cloneDeep(this.editForm)
        form.goods_cat = form.goods_cat.join(',')
      //  console.log(form)

        const { data: res } = await this.$http.put('goods/' + form.goods_id, form)
        if (res.meta.status !== 200) {
          return this.$message.error('修改商品失败!')
        }
        this.$message.success('修改商品成功!')
        this.$router.push('/goods')
      })
    }
编辑功能其实还差商品参数和静态属性还没完全弄好,经过了很久的尝试之后,我猜测后台有一些不周全的地方

如果一个商品是新添加的,那么我根据id查询得到的商品信息的参数/属性是以 空格 为分隔符的字符串
而如果是数据库中本来就存在的商品,我点击编辑按钮,通过id查询得到的信息的参数/属性 是以 逗号","为分隔符的字符串
加上我对elementui使用不熟练,目前,还无法完全实现这个功能,等日后有时间再进行完善。目前的进度,是能够做到成功修改商品基本信息,商品图片,商品描述三个部分。

Edit.vue完整代码如下:

相关内容

热门资讯

“我要打10个”的伊朗,缺油了... 如果说两周前,伊朗军方还在电视台上拍着胸脯保证“一切正常,我们赢麻了”,那么现在,这层窗户纸算是被彻...
REDMI K90 Max发布... 4 月 21 日,REDMI K90 Max 正式发布。作为 REDMI K 系列全新成员,REDM...
A股,突变!七大巨头,集体异动... 市场明显起了变化!早上,紫金矿业和宁德时代两大巨头都在发布利好之后意外回落,与此同时,有色和电池板块...
“农夫”们才入局,补水啦已经签... 文 | 陶魏斌2026年世界杯开赛在即,补水啦官宣了自己的品牌代言人——姆巴佩,当今足球世界的顶级球...
新市场扭亏、国内转型阵痛 极兔... 独立 稀缺 穿透仍有不少硬仗要打作者:闻道编辑:李莉风品:一然来源:铑财——铑财研究院新曲线越烧越旺...
盘后突发利空!油价涨破100,... 今天的行情再次应了那句话:不要光站在那里,要站在光里!隔壁港股大跌,A股低开高走,上证指数站上410...
纠结的万华化学:不论业绩如何,... 在周期股里,万华化学这两年的表现有点别扭,化工赛道热门企业华鲁恒升、新和成、卫星化学等纷纷在今年创出...
手机涨价潮来袭,OPPO刘作虎... 4月21日,OPPO正式发布Find X9s Pro与Find X9 Ultra 影像双旗舰新品。作...
航空业“油荒”危机将至:海湾出... 财联社4月22日讯(编辑 刘靖怡)随着全球航运咽喉霍尔木兹海峡因美伊对峙被封锁,海湾地区对国际市场的...
调研|平安银行对公和零售信贷投... 截至今年3月末,创业板上市公司占A股上市公司总数1/4,总市值近18万亿元,是全球最具活力的市场之一...