【js判断文件类型】js上传文件前判断文件类型

场景:使用antd的Upload上传文件前判断文件类型,只允许上传指定类型文件

由于要判断.amr类型的音频,一开始的写法:

 beforeUpload = file => {
      const isLt2M = file.size / 1024 / 1024 < 2;
      const isValid = file.type === "audio/amr";
      if (!isValid) {
        message.warn("上传失败,请选择.amr格式");
      }
      if (!isLt2M) {
        message.warn("上传失败,大小不能超过2M");
      }
      return isValid && isLt2M;
    }

但是反映文件类型错误。原因是file.type只能识别常见类型的文件格式,不常见的文件类型会返回空字符串,最好不要依赖这个属性作为唯一验证方案。

后来改成通过文件后缀判断。

// 获取文件后缀
  getFileSuffix = name => {
    const index = name.lastIndexOf(".");
    const len = name.length;
    return name.substring(index, len) || "-";
  };
  
  beforeUpload = file => {
  	  const suffix = this.getFileSuffix(file.name);
      const isLt2M = file.size / 1024 / 1024 < 2;
      const isValid = suffix === ".amr";
      if (!isValid) {
        message.warn("上传失败,请选择.amr格式");
      }
      if (!isLt2M) {
        message.warn("上传失败,大小不能超过2M");
      }
      return isValid && isLt2M;
    }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值