<template>
  <div id="app">
    <!-- 
      action:存放的是文件上传到服务器的接口地址
    -->
    <!--组件里 show-file-list  是否显示已上传文件列表 -->
    <!--组件里 on-success  文件上传成功时的钩子,成功时触发 -->
    <!-- before-upload  上传文件之前的钩子,参数为上传的文件,若返回 false 或者返回 Promise 且被 reject,则停止上传。 -->
     <!-- action存放的是上传到服务器的接口地址 -->
    <el-upload
      drag
      action="/single1"
      :show-file-list="false"
      :on-success="handleSuccess"
      :before-upload="beforeUpload"
    >
      <i class="el-icon-upload"></i>
      <div class="el-upload__text">
        将文件拖到此处,或
        <em>点击上传</em>
      </div>
    </el-upload>

    <!-- IMG -->
    <div class="uploadImg" v-if="img">
      <img :src="img" alt />
    </div>
  </div>
</template>

<script>
/*
 * 文件上传有两套方案:
 *   1. 基于文件流(form-data)  element-ui上传组件默认是基于文件流的
 *   2. 客户端需要把文件转化为BASE64
 *
 * 默认上传
 *   格式:multipart/form-data
 *   数据格式:form-data
 *      file 文件流信息
 *      filename 文件名字
 *   上传成功后获取服务器返回信息,通知on-success回调函数执行
 * 内部封装了ajax
 */
export default {
  name: "App",
  data() {
    return {
      img: null,
    };
  },
  methods: {
    // <!--组件里 on-success 文件上传成功时的钩子,成功时触发 result是服务器返回的结果-->  
    handleSuccess(result) {
      //通过服务器返回的code值,判断成功   然后将返回的path地址,赋值给img
      if (result.code == 0) {
        this.img = result.path;
      }
    },
    // 组件里before-upload上传文件之前的钩子,参数为上传的文件,若返回 false 或者返回 Promise 且被 reject,则停止上传
    // 在这里面判断一些条件,例如多大的,什么格式的才能上传
    beforeUpload(file) {
      // 格式校验----------------------------
      console.log(file)           //可以知道得到文件的type类型和文件的size大小
      let { typesize } = file;    //file这个属性因为包含这两个值,分别赋值给变量
     //判断文件的格式  正则表达式  匹配文件类型
      if (!/(png|gif|jpeg|jpg)/i.test(type)) {
        this.$message("文件合适不正确~~");    //组件的提示方法
        return false;                        //既然判断出格式不正确,那么就return  终止函数,不往下走了
      }
     //判断文件大小1024B=1KB  1024KB=1MB   假设限定必须在200M以内的
      if (size > 200 * 1024 * 1024) {
        this.$message("文件过大,请上传小于200MB的文件~~");
        return false;
      }

      return true;           //  beforeUpload(file)  最终是返回ture的
    },
  },
};
</script>