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

Posted wgl0126

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用Element的upload上传组件,不使用action属性上传相关的知识,希望对你有一定的参考价值。

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属性上传的主要内容,如果未能解决你的问题,请参考以下文章

vue 使用element-ui的el-upload httprequest实现上传文件到后台的功能

附件el-upload组件列表清空

如何使用element-ui的upload组件实现上传文件到七牛

vue使用Element el-upload 组件

页面中使用多个element-ui upload上传组件时绑定对应元素

关于vue-element-admin的采坑记录-upload组件图片上传问题