el-upload文件上传预处理(文件名称长度、大小、格式、单文件控制)

注意:

1、el-upload的before-upload事件内的校验规则,只有在auto-upload="true"(实时上传)的时候才会生效,如果auto-upload="false",校验规则可写在手动上传的方法里。

2、el-upload的accept即使设置了接收的文件格式,仍可在选择文件时,选择右下角选择所有文件格式,绕开el-upload的格式校验,所以对文件格式很严格的场景下,可像下文内的校验一样,对文件格式进行单独判断。

methods: {
        // 文件上传预处理
        beforeUpload(file, fileList) {
            if(file.status !== 'ready') {
                return false;
            }
            
            // 文件名称长度校验
            let fileNameLen = file.name.length;
            if(fileNameLen > 256) {  
                this.$message({
                    message:'文件名称过长',
                    type:'error',
                    duration: 1000
                });
                // 文件列表内移除当前选择的文件
                this.fileList = fileList.filter((item) => {return item != file}); 
                return false;
            }

            // 文件格式校验
            if(!/\.(xls|xlsx)/.test(file.name)) {
                this.$message({
                    message: "请上传格式为xls、xlsx的文件",
                    type: "error",
                    duration: 1000
                })
                this.fileList = fileList.filter((item) => {return item != file});
                return false;
            }

            // 文件大小校验
            const fileSize = file.size / 1024 / 1024 < 5;
            if(!fileSize) {
                this.$message.error("文件大小不要超过5M");
                this.fileList = fileList.filter((item) => {return item != file});
                return false;
            }

            // 单文件控制
            if(fileList.length > 1) {
                fileList.splice(0, 1);
            }
         }

    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值