elementui 图片顺序-vue项目中结合element ui解决连续上传多张图片以及图片编辑的问题

编码是面向需求的,所以在编码之前一定要弄清楚需要的结果是什么elementui 图片顺序,然后开始编码。

现在简单说一下需求:如下图所示,点击红色“+”按钮,连续生成多个图片上传框。 每个图片上传框独立上传图片elementui 图片顺序,编辑互不影响。

element ui:
转账汇款信息 +
{{item.up_btn}}
删除

 data() {
      return {
 // 上传成功后的id
        uploadId: '',
        // 重新上传成功后的id
        resetUploadId: '',
        // upload控件tag
        uploadTag: 0,
        // 上传图片文件列表
        fileList: [],
        upItem: {},
//        所有账号-select
        accVal: '1',
//        图片上传框初始数组
        datas_upload: [{ up_btn: '上传图片', upbtnGroup: false, imgId: '', url: '' }],
//       图片初始id数组
        imgArryid: [],
      }  
},
methods: {
//      点击“+”按钮生成图片上传框
      addupload() {
        this.datas_upload.push({ up_btn: '上传图片', upbtnGroup: false, imgId: '', url: '' })
      },
//      获取图片id
    getimgId() {
      for (var i = 0; i < this.datas_upload.length; i++) {
        this.imgArryid.push(this.datas_upload[i].imgId)
      }
      return this.imgArryid
    },
//      图片上传
      getUploadTag(item, index) {
//        console.log(response, file, fileList, 564)
        this.uploadTag = index 
        this.upItem = item
      },
//      图片上传成功
      uploadSuc(response, file, fileList) {
        // 把图片id添加到 uploadId 数据中
        this.datas_upload[this.uploadTag].imgId = response.id
        this.uploadId = response.id
        this.upItem.up_btn = '重新上传图片'
        this.upItem.upbtnGroup = true
        var imgs = 'imgs' + this.uploadTag
        this.upItem.url = file.url
      },
      //      上传图片-删除
      delupload(item, index) { 
        for (var i = 0; i < this.datas_upload.length; i++) {
          if (i != 0) {
            if (index == i) {
              this.datas_upload.splice(i, 1)
              this.datas_upload[index].imgId = ''
            }
          } else if (i == 0) {
            console.log(index, item, 563)
            this.datas_upload[index].imgId = ''
            this.datas_upload[index].url = ''
            item.up_btn = '上传图片'
            item.upbtnGroup = false
          }
        }
      },
      // 重新上传-success
      resetUploadSuc(response, file, fileList) {
        this.resetUploadId = response.id
        this.conResUploadView = false
        this.conRessubmitView = true
      }
}

注意:对于能够生成多个数据的,首先想到的是利用链表的V-进行循环遍历。 默认有一个图片上传框用于初始化,所以给该字段一个初始化的对象,每次点击按钮都会去该字段添加新对象,并使用数据的单向绑定生成对应的DOM元素达到理想的效果。