码迷,mamicode.com
首页 > Web开发 > 详细

使用Element的upload上传组件,不使用action属性上传

时间:2019-10-11 10:42:31      阅读:157      评论:0      收藏:0      [点我收藏+]

标签:else   button   das   点击   vat   创建文件   上传   template   def   

1.需要实现的效果如下图,在点击提交的时候再提交file数据,和其他数据统一上传,我把file转换成了base64的格式,可以再上传之前显示缩略图

技术图片

 

2.代码分析

action属性值为"#"

增加了:http-request="httpRequest"方法

解释:

http-request  覆盖默认的上传行为,可以自定义上传的实现

<template>
  <div>
    <el-upload
      class="avatar-uploader"
      action="#"
      :http-request="httpRequest"
      :show-file-list="false"
      :before-upload="beforeAvatarUpload">
      <img v-if="data.imageUrl" :src="data.imageUrl" class="avatar">
      <i v-else class="el-icon-plus avatar-uploader-icon"></i>
    </el-upload>
    <div class="content">
      <p>
        <span>文章标题</span>
        <el-input v-model="data.title" placeholder="文章标题"></el-input>
      </p>
      <p>
        <span>文章简介</span>
        <el-input v-model="data.summary" placeholder="文章简介"></el-input>
      </p>
      <p>
        <span>文章内容</span>
        <el-input v-model="data.content" placeholder="文章内容"></el-input>
      </p>
      <p>
        <el-button type="primary" @click="onSubmit" class="submitButton">提交</el-button>
      </p>
    </div>
  </div>
</template>

js相关代码

httpRequest方法主要处理显示缩略图,并且将需要用到的file转换成base64的文件格式

export default {
  data () {
    return {
      data: {
        title: ‘‘,
        summary: ‘‘,
        content: ‘‘,
        imageUrl: ‘‘
      }
    }
  },
  methods: {
    // 上传之前的格式设置
    beforeAvatarUpload (file) {
      const isJPG = file.type === ‘image/jpeg‘
      const isLt2M = file.size / 1024 / 1024 < 2
      if (!isJPG) {
        this.$message.error(‘上传头像图片只能是 JPG 格式!‘)
      }
      if (!isLt2M) {
        this.$message.error(‘上传头像图片大小不能超过 2MB!‘)
      }
      return isJPG && isLt2M
    },
    httpRequest (data) {
      let _this = this
      let rd = new FileReader() // 创建文件读取对象
      let file = data.file
      rd.readAsDataURL(file) // 文件读取装换为base64类型
      rd.onloadend = function (e) {
        _this.data.imageUrl = this.result // this指向当前方法onloadend的作用域
      }
    },
    onSubmit () {
      console.log(this.data)
      console.log(‘submit!‘)
    }
  }
}
</script>

 

使用Element的upload上传组件,不使用action属性上传

标签:else   button   das   点击   vat   创建文件   上传   template   def   

原文地址:https://www.cnblogs.com/wgl0126/p/11652534.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!