el-upload组件上传单张或多张图片到腾讯云方法

507 阅读2分钟

第一步、引入upload组件

<el-upload
      :class="{disable:fileList.length > 0}" //当组件挂载了一个文件之后,加号就会消失
      action="#"   //为必填属性:文件上传的地址
      list-type="picture-card" // 组件的样式类型
      :file-list="fileList" //必填属性:挂载到组件的文件的列表,fileList为一个数组,每一个元素都是一个文件对象
      :on-change="onChange" // 每当有文件上传时就会调用这个函数,自带两个参数,第一个为新的文件列表数组,第二个为新上传的文件对象
      :on-remove="onRemove" // 每当有文件从组件被删除就会调用这个函数,自带两个参数,第一个为新的文件列表数组,第二个为删除的文件对象
      
      :before-upload="beforeUpload" // 上传文件前会触发,一般用于文件的校验,自带一个参数,为新上传的文件对象
      :http-request="httpRequest" // 文件上传到仓库后会调用,自带一个参数,为文件上传行为的对线
    >
      <i class="el-icon-plus" />
</el-upload>

// style
 .disable{
    ::v-deep .el-upload--picture-card{
        display: none;
    }
}

第二步,配置cos并实例化cos对象

下载引入cos  npm i cos-js-sdk-v5
import COS from 'cos-js-sdk-v5'
//实例化cos对象
var cos = new COS({
  SecretId: '',
  SecretKey: ''
})

第三步,声明上传文件各阶段的函数

 methods: {
    onChange(data, newList) {
      this.fileList = newList
    },
    onRemove(data, newList) {
      this.fileList = newList
    },
    beforeUpload(file) {
      console.log(file)
      const whiteList = ['image/jpeg', 'image/png']
      if (whiteList.indexOf(file.type) === -1) {
        this.$message.error('只支持jpeg/png格式')
        return false
      }
      if (file.size > 1 * 1024 * 1024) {
        this.$message.error('文件不能超过1m')
        return false
      }
    },
    httpRequest(params) {
      console.log('上传成功', params)
      cos.putObject({
        Bucket: '腾讯云储存桶名字', /* 填入您自己的存储桶,必须字段 */
        Region: 'ap-guangzhou', /* 存储桶所在地域,例如ap-beijing,必须字段 */
        Key: 文件的姓名, /* 存储在桶里的对象键(例如1.jpg,a/b/test.txt),必须字段 */
        StorageClass: 'STANDARD',
        Body: params.file, // 上传文件对象
        onProgress: function(progressData) {
          console.log(JSON.stringify(progressData))
        }
      }, (err, data) => {
        console.log(err || data)
        if (!err) { // 当没有err时,上传成功,返回腾讯云返回的data
          // 因为上传到腾讯云是异步操作,先调用on-change定义fileList,
          // 再上传的,所以要在上传后手动修改fileList里面的文件对象的属性
          // 单张图片方法
          this.fileList[0].status = 'success' //成功后手动修改fileList中的文件对象属性
          this.fileList[0].url = 'http://' + data.Location
          
          // 多张图片方法(每次上传成功后都修改数组的最后一个文件对象的状态)
          this.fileList[this.fileList.length - 1]['url'] = 'http://' + data.Location
          this.fileList[this.fileList.length - 1]['status'] = 'success'
          console.log(this.fileList)
        }
      })
    }
  }