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元素,达到想要的效果。

 

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
以下是使用Element UIvue-quill-editor实现上传图片的完整代码: 1. 安装需要的依赖: ``` npm install element-ui vue-quill-editor axios -S ``` 2. 在main.js引入依赖并注册组件: ```javascript import Vue from 'vue' import ElementUI from 'element-ui' import 'element-ui/lib/theme-chalk/index.css' import VueQuillEditor from 'vue-quill-editor' import 'quill/dist/quill.core.css' import 'quill/dist/quill.snow.css' import 'quill/dist/quill.bubble.css' import App from './App.vue' import axios from 'axios' Vue.prototype.$axios = axios Vue.use(ElementUI) Vue.use(VueQuillEditor) new Vue({ el: '#app', render: h => h(App) }) ``` 3. 在需要使用富文本编辑器的组件,添加以下代码: ```html <template> <div> <quill-editor v-model="content" :options="editorOption"></quill-editor> </div> </template> <script> export default { data() { return { content: '', editorOption: { modules: { toolbar: [ ['bold', 'italic', 'underline', 'strike'], // 加粗,斜体,下划线,删除线 [{ 'header': 1 }, { 'header': 2 }], // 标题,键值对的形式;1、2表示字体大小 [{ 'header': [1, 2, 3, 4, 5, 6, false] }], // 标题,键值对的形式;1、2表示字体大小 [{ 'color': [] }, { 'background': [] }], // 字体颜色,字体背景颜色 [{ 'font': [] }], // 字体 [{ 'align': [] }], // 对齐方式 ['blockquote', 'code-block'], // 引用,代码块 ['link', 'image', 'video'], // 链接,图片,视频 ['clean'] // 清除字体样式 ], // 上传图片 imageUploader: { upload(url, fd) { return new Promise((resolve, reject) => { this.$axios.post(url, fd).then(res => { resolve(res.data.data) }).catch(err => { reject(err) }) }) }, format(res) { return res.data.url } } } } } } } </script> ``` 注:这里的上传图片使用了axios,需要在使用前先引入并设置Vue.prototype.$axios = axios 这样就可以使用Element UIvue-quill-editor实现上传图片功能了。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值