vue项目中结合element ui解决连续上传多张图片及图片编辑问题

编码都是以需求为导向的,所以编码前一定要弄清楚需要的结果是什么,然后再开始编码。

现在简单的说下需求:如下图所示,点击蓝色的“+”按钮,可以连续生成多个图片上传框,每个图片上传框都是单独上传图片,编辑互不影响。

element ui:
<div class="form-right">
                        <div class="right_btns">转账汇款信息
                            <el-button type="primary" @click="addupload" v-if="adduploadShow">+</el-button>
                        </div>
                        <div class="upload_parent" v-if="uploadShow" v-for="(item, index) in datas_upload" :key="index">
                            <div class="defind_img_s">
                                <img :src="item.url" class="defind">
                                <el-upload
                                        :ref='"upload" + index'
                                        name="img_b"
                                        class="upload-demo"
                                        :action="uploadUrl"
                                        :headers="upload_hearder"
                                        :on-remove='handleRemove'
                                        :on-success='uploadSuc'
                                        :file-list='fileList'
                                        :show-file-list="false">
                                    <div @click='getUploadTag(item, index)' class="up_btns">{{item.up_btn}}</div>
                                </el-upload>
                                <span v-show="item.upbtnGroup" class="upbtnGroups"
                                      @click="delupload(item,index)">删除</span>
                            </div>
                        </div>
                    </div>
 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元素,达到想要的效果。

 


http://www.niftyadmin.cn/n/843523.html

相关文章

JAVA 接口题目1

转载于:https://www.cnblogs.com/xt641151246/p/5532867.html

抽屉式导航可能减少产品一半的用户參与度

设想你须要设计一个含有很多页面和模块&#xff0c;不能在一屏内显示全然的应用。你一定会首先想到去设计一个底部或顶部的Tab导航。等一下。多出来的一排导航看上去有点碍眼?我们尝试下把他们收到側边栏里。或者叫安卓团队给它的名字“側边抽屉导航”。 假设你们的应用的也是…

Spring刷题笔记 面试题 请举例解释@Required注解?

在产品级别的应用中&#xff0c;IoC容器可能声明了数十万个bean&#xff0c;bean与bean之间有着复杂的依赖关系。设值注解方法的短板之一就是验证所有的属性是否被注解是一项十分困难的操作。可以通过在<bean>中设置“dependency-check”来解决这个问题。 在应用程序的生…

Remastersys打包你自己的ubuntu成iso文件,保存原来的所有配置

你是不是辛辛苦苦地配好了ubuntu结果不久又重装&#xff0c;然后又重新配置很久呢&#xff1f; 笔者好不容易配置好了torch&#xff0c;但是换硬盘&#xff0c;于是就想到了将ubuntu打包成iso文件&#xff0c;下次直接安装&#xff0c;然后配置好的东西都搬过来了。 采用Remast…

Spring刷题笔记 面试题 请举例解释@Autowired注解?

Autowired注解对自动装配何时何处被实现提供了更多细粒度的控制。 Autowired注解可以像Required注解、构造器一样被用于在bean的设值方法上自动装配bean的属性&#xff0c;一个参数或者带有任意名称或带有多个参数的方法。 比如&#xff0c;可以在设值方法上使用Autowired注解…

vue-cli搭建的项目中localhost能访问而ip不能访问的解决方法

只需要在config文件夹里面的index.js文件里面的module.exports下面的dev中的 host:localhost 改为 host:0.0.0.0 ,然后重启服务器就可以访问了。

fullcalendar 使用教程

$(#calendar).fullCalendar({header : {left : today prev,next,center : title,right : month,basicWeek},buttonText : {month : 月视图,week : 周,day : 日视图},defaultDate : date,eventPhase : 5,editable : false,// 可以拖动selectable : true,eventLimit : true, even…

vue项目中使用ref来获取dom及给class绑定属性的命名注意事项

使用ref来获取dom的时候&#xff0c;在给ref命名的时候尽量使用驼峰命名法&#xff0c;不能使用-&#xff08;像‘auto-play’这样的命名就是错误的&#xff0c;应该改为autoPlay这样&#xff09;&#xff1b; 而在给class绑定属性的时候&#xff0c;也应该避免使用-。例如&…