博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
blueImp/jQuery file upload 的正确用法(限制上传大小和文件类型)
阅读量:6638 次
发布时间:2019-06-25

本文共 1738 字,大约阅读时间需要 5 分钟。

这个插件太出名了,几乎能完成所有能想象的到的效果,包括进度条、拖拽、甚至现在已经完美支持图片视频等的处理,三个字形容就是屌爆了。最近在做上传这一部分,发现网上对于上传文件大小的限制和类型检测等的方法都不妥当,包括老外写的。blueimp提供了完整的解决方案,验证当然是有的,所以对于一个普通的上传组件来说需要下面三个组件:

1
2
3
<script src="//cdn.bootcss.com/blueimp-file-upload/9.12.5/js/jquery.fileupload.js"></script>
 
<script src="//cdn.bootcss.com/blueimp-file-upload/9.12.5/js/jquery.fileupload-process.js"></script>
 
<script src="//cdn.bootcss.com/blueimp-file-upload/9.12.5/js/jquery.fileupload-validate.js"></script>

大部分文章都没有包含process和validate这两个组件,前者负责处理上传过程中各个事件的管理,validate则是对验证的支持,如果不包含这两个组件,那么只能像下面这样来做一些验证:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
add: function (e, data) {
        
var uploadErrors = [];
 
        
var acceptFileTypes = /\/(pdf|xml)$/i;
        
if(data.originalFiles[0]['type'].length && !acceptFileTypes.test(data.originalFiles[0]['type'])) {
            
uploadErrors.push('Tipo de Archivo no Aceptado');
        
}
 
        
console.log(data.originalFiles[0]['size']) ;
        
if (data.originalFiles[0]['size'] > 5000000) {
            
uploadErrors.push('Tamaño de Archivo demasiado Grande');
        
}
        
if(uploadErrors.length > 0) {
            
alert(uploadErrors.join("\n"));
        
} else {
            
data.context = $('<p/>').text('Subiendo...').appendTo(document.body);
            
data.submit();
        
}
 
    
}

那么用官方的方式可以如下

1
2
3
4
5
6
7
8
9
10
11
12
13
14
<pre>acceptFileTypes: /(\.|\/)(gif|jpe?g|png)$/i,
maxFileSize: 99 * 1024 * 1024,
minFileSize: 5,
maxNumberOfFiles: 50,
messages: {
    
maxFileSize: 'File exceeds maximum allowed size of 99MB',
    
acceptFileTypes: 'File type not allowed'
},processfail: function (e, data) {
    
var currentFile = data.files[data.index];
    
if (data.files.error && currentFile.error) {
        
// there was an error, do something about it
        
console.log(currentFile.error);
    
}
}</pre>

明显简洁很多。

本文转自today4king博客园博客,原文链接:http://www.cnblogs.com/jinzhao/p/5914211.html,如需转载请自行联系原作者

你可能感兴趣的文章
Hibernate综合问题
查看>>
iOS:自定义工具栏、导航栏、标签栏
查看>>
Ext,保存输入记录,并会提示输入
查看>>
学习lofter 让图片适应各个分辨率的方法
查看>>
Android的Message机制(简单小结)
查看>>
GEOS库的学习之二:简单几何图形的创建
查看>>
[转化率预估-4]特征选择-简介
查看>>
2012年度江西省科学技术奖授奖项目名单
查看>>
WPF自定义控件与样式(12)-缩略图ThumbnailImage /gif动画图/图片列表
查看>>
编程教程网站
查看>>
java web 答辩总结
查看>>
Base64编码解码
查看>>
POJ1502(Dijkstra)
查看>>
程序猿必须知道10算法及其大有用的解说基地
查看>>
thinkphp中的验证码的实现
查看>>
Oracle 自己主动内存參数依赖性
查看>>
OpenLayers学习笔记4——使用jQuery UI实现測量对话框
查看>>
Leetcode Triangle
查看>>
TBDR缺点
查看>>
apache开源项目--ZooKeeper
查看>>