使用腾讯云存储

262 阅读1分钟
<template>
  <!-- 上传组件 -->
  <div>
    <!-- :class="{ class名称:布尔值 }" -->
    <!-- el-upload之所以能够显示图片 是因为 fileList中有值 -->
    <el-upload
      list-type="picture-card"
      :file-list="fileList"
      :on-preview="preview"
      :on-remove="handleRemove"
      :on-change="changeFile"
      :before-upload="beforeUpload"
      :http-request="upload"
      action="#"
      :class="{disabled: fileComputed}"
    >
      <i class="el-icon-plus" />
    </el-upload>
    <el-progress v-if="showPercent" :percentage="percent" style="width: 180px" />

    <!-- 预览图片 -->
    <el-dialog :visible.sync="showDialog" title="图片预览">
      <img :src="imgUrl" alt style="width:100%" />
    </el-dialog>
  </div>
</template>

<script>
import COS from 'cos-js-sdk-v5'
import { defineComponent, reactive, toRefs } from 'vue'
const cos = new COS({
  SecretId: 'AKIDfFafT0GGzRcW8TXLs87rLYT8SWJp54mD', // 身份识别 ID
  SecretKey: 'B5i49xUkjRt3wYtxkGUR7WfX8SVIn1zg' // 身份密钥
})
export default defineComponent({
  setup() {
    const state = reactive({
      showPercent: false, // 控制进度条的显示和隐藏
      percent: 0, // 当前的进度
      showDialog: false, // 默认隐藏
      imgUrl: '',
      fileList: []
    });
    const preview = (file) => {
      state.imgUrl = file.url
      state.showDialog = true
    };
    // file就是要删除的file
    const handleRemove = (file) => {
      // 根据file中uid将当前的fileList中的数据进行移除
      state.fileList = state.fileList.filter(item => item.uid !== file.uid)
      // filter方法会得到一个新的数组
    };
    // 不能够一味 的进行push 因为该函数会被多次调用 fileList其实就是当前最新的文件列表
    const changeFile = (file, fileList) => {
      // this.fileList = [...fileList]
      state.fileList = fileList.map(item => item)
    };
    // 上传之前检查
    const beforeUpload = (file) => {
      //   console.log(file)
      // 要开始做文件上传的检查了
      // 文件类型 文件大小
      const types = ['image/jpeg', 'image/gif', 'image/bmp', 'image/png'];
      if (!types.includes(file.type)) {
        Message.error('上传图片只能是 JPG、GIF、BMP、PNG 格式!');
        return false;
      };
      //   文件大小
      const maxSize = 25 * 1024 * 1024;
      if (maxSize < file.size) {
        Message.error('图片最大的大小为5M');
        return false;
      };
      return true; // 要返回true
    };
    // 上传到腾讯云
    // 自定义上传动作
    const upload = (params) => {
      // params中的file就是要上传的图片文件
      //   console.log(params.file)
      if (params.file) {
        state.showPercent = true // 显示进度条
        //   上传对象到腾讯云
        cos.putObject({
          Bucket: 'trumpdown-1302806742', /* 每个人的存储桶名称 */
          Region: 'ap-beijing', /* 存储桶所在地域,必须字段 */
          Key: params.file.name, /* 文件名称 */
          StorageClass: 'STANDARD', // 固定值
          Body: params.file, // 上传文件对象
          onProgress: (progressData) => {
            // console.log(progressData.percent * 100)
            state.percent = progressData.percent * 100
          }
        }, (err, data) => {
          console.log(err)
          if (data.statusCode === 200 && data.Location) {
            //   认为此时上传成功
            // 需要知道当前的这个地址是谁的url地址
            //  params.file.uid  => 当前上传文件的标识  如果找到了一一样的uid 就表示他们是一张图片
            console.log(state.fileList)
            // 这样相当于将原来的旧本地地址换成了新地址
            state.fileList = state.fileList.map(item => {
              // 将本地的地址替换成线上已经放在腾讯云之后的地址
              if (item.uid === params.file.uid) {
                // upload 为true的意思是 表示这张图片 已经上传过了 已经不是本地图片了
                return { url: 'http://' + data.Location, upload: true }
              }
              return item
            })
            state.showPercent = false // 关闭进度条
            state.percent = 0 // 将进度归0
          }
        })
      }
    };
    return {
      ...toRefs(state),
      preview,
      handleRemove,
      changeFile,
      beforeUpload,
      upload
    };

  },
  computed: {
    // 只要该计算属性为true 就表示 我们需要隐藏上传按钮
    fileComputed() {
      return this.fileList.length === 1
    }
  }
})
</script>

<style>
.disabled .el-upload--picture-card {
  display: none;
}
</style>