js 限制 input 文件上传的大小和格式

最近在项目中需要一些文件大小和格式的校验,整理了一下作为日后的参考

废话不多说,上代码:

Javascript:

//验证上传文件大小和类型

/**
 * 
 * @param {this} value_ [获取input对象,一般为this]
 * @param {[number]} size_ [文件限制的大小,单位为kb]
 * @param {[string]} type_ [文件类型,当前支持image和office]
 * @param {[function]} callback [验证通过的回调]
 */

function fileValid (value_, size_, type_, callback) {
    var file = value_.files[0]
    var fileSize = (file.size / 1024).toFixed(0)
    var fileType = value_.value.substring(value_.value.lastIndexOf("."))

    if (fileSize > size_) {
        alert('文件过大')
        return false
    }

    switch (type_) {
        case 'image':
            if (!fileType.match(/.jpg|.jpeg|.gif|.png|.bmp/i)) {
                alert('请上传图片')
                return false;
            }
            break;
        case 'office':
            if (!fileType.match(/.doc|.docx|.xls|.xlsx|.ppt|.pptx/i)) {
                alert('请上传word、excel或ppt文件')
                return false;
            }
            break;
        default:
            console.error('type_参数设置不正确!')
            return false;
            break;
    }

    callback()
}

HTML:

<input type="file" id="upload-file">

<script>
    $('#upload-file').change(function() {
        fileValid(this, 2048, 'image', function() {
            alert('success')
        })
    })
</script>

 

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值