webuploader解决不能重复上传问题及一些常见问题处理
uploader = WebUploader.create({
swf: 'resources/js/webuploader-0.1.5/Uploader.swf',
// 文件接收服务端。
server: settings.url,
// 选择文件的按钮。可选。
// 内部根据当前运行是创建,可能是input元素,也可能是flash。
pick : '#picker',
// 不压缩image, 默认如果是jpeg,文件上传前会压缩一把再上传!
resize : false
});
以上代码是不支持重复上传:根据查看webuploader文档里面有个duplicate属性,是可选的,true为可重复,false为不可重复,默认为undifind,也是不可重复。所以只需在属性的后面追加 duplicate:true 就可以实现重复上传。
uploader = WebUploader.create({
swf: 'resources/js/webuploader-0.1.5/Uploader.swf',
// 文件接收服务端。
server: settings.url,
// 选择文件的按钮。可选。
// 内部根据当前运行是创建,可能是input元素,也可能是flash.
pick : '#picker',
// 不压缩image, 默认如果是jpeg,文件上传前会压缩一把再上传!
resize : false,
//可重复上传
duplicate :true
});
文件上传控件:webuploader + jQuery,开源而且好用。但是在使用过程中出现一些问题:
1、上传多张图片,图片的顺序会乱掉。解决方法:threads:1
2、文件没有按照原来比例上传,1M多的文件会被压缩,解决方法:compress: false
3、选择文件的时候浏览器反应迟钝,解决方法:
accept: {
title: 'Images',
extensions: "gif,jpg,jpeg,png",
mimeTypes: ".gif,.jpg,.jpeg,.png"
}
4、ie浏览器,上传文件失败,有可能是"swf"定义的文件路径不对。ie浏览器是用flash模式上传文件的。
var fileCount=;
var fileSize=;
var uploader;
var errorarr=new Array();
function initFile(){
uploader = WebUploader.create({
auto: true,
// swf文件路径
swf : '/ueditor/third-party/webuploader/Uploader.swf',
// 文件接收服务端。
server : "upFiles.do",
// 选择文件的按钮。可选。
// 内部根据当前运行是创建,可能是input元素,也可能是flash.
pick : '#filePicker',
// 不压缩image, 默认如果是jpeg,文件上传前会压缩一把再上传!
//resize : false,//这个不起作用,要用compress
compress: false,//webuploader默认压缩图片,设置compress:false,可以按照原始比例上传图片
accept: {
title: 'Images',
extensions: "gif,jpg,jpeg,png",
mimeTypes: ".gif,.jpg,.jpeg,.png"//解决WebUploader在谷歌浏览器中反应缓慢迟钝,虽然解决了问题,但是火狐浏览器,选择文件的时候不做限制了 },
fileVal:"upfile",//设置文件上传域的name。
fileSizeLimit: * * ,//所有文件上传的大小限制,单位字节
fileSingleSizeLimit: * * ,//单张图片上传限制大小,单位字节
fileNumLimit:,//文件上传数量限制
threads://上传并发数。允许同时最大上传进程数,为了保证文件上传顺序
});
/*当文件被加入队列以后触发。
@param file File对象
@param ret 服务器返回的数据
*/
uploader.on('uploadSuccess', function (file, ret) {
var $file = $('#' + file.id);
try {
if (ret.state == 'SUCCESS') {
var json={};
json.dataid=ret.picId;
json.src=ret.url;
json.width=ret.width;
json.height=ret.height;
if(!putPicMap(json)){//加入图片列表
return false;
}
}else {
//console.log("faile","aa");
}
} catch (e) {
//console.log("faile","bb");
}
});
/**
*文件上传失败
*code=F_DUPLICATE 上传文件重复
**/
uploader.on('error', function (code, file) {
var name=file.name;
var str="";
switch(code){
case "F_DUPLICATE":
str=name+"文件重复";
errorarr.push(str);
break;
case "Q_TYPE_DENIED":
str=name+"文件类型 不允许";
errorarr.push(str);
break;
case "F_EXCEED_SIZE":
var imageMaxSize = ;//通过计算
str=name+"文件大小超出限制"+imageMaxSize+"M";
errorarr.push(str);
break;
case "Q_EXCEED_SIZE_LIMIT":
errorarr.push("超出空间文件大小");
break;
case "Q_EXCEED_NUM_LIMIT":
errorarr.push("抱歉,超过每次上传数量图片限制");
default:
str=name+" Error:"+code;
}
});
uploader.on( 'all', function( type, arg1, arg2 ) {
if(type=="startUpload"){//开始上传
uploadchange();
}else if(type=="uploadFinished"){//上传结束
if(errorarr.length>){
alert(errorarr.join("\n"));
}
//清空错误信息
errorarr.length=;
}
});
}
/**
* 本地上传图片,改变上传的相册,文件上传的路径也会改变
*/
function uploadchange(){
//这里可以限制文件上传个数,未做
/* 添加额外的GET参数 */
uploader.option('server', "upFiles.do?aa=3");
}
webuploader解决不能重复上传问题及一些常见问题处理的更多相关文章
- Vue2.0结合webuploader实现文件分片上传
Vue项目中遇到了大文件分片上传的问题,之前用过webuploader,索性就把Vue2.0与webuploader结合起来使用,封装了一个vue的上传组件,使用起来也比较舒爽. 上传就上传吧,为什么 ...
- 解决Web Uploader上传文件和图片 延迟和not defined
1.出现list not define时,var $list = $("#fileList"); 2.选择文件框有延迟,可能是因为选择文件类型过多 mimeTypes: 'imag ...
- 使用WebUploader实现文件批量上传,进度条显示功能
知识点:利用WebUploader,实现文件批量上传,并且实时显示文件的上传进度 参考官方文档:http://fex.baidu.com/webuploader/ (1)引入三个资源 JS,CSS,S ...
- 使用WebUploader进行文件图片上传
官方文档:http://fex.baidu.com/webuploader/getting-started.html 引入Webuploader的css和js文件,下载地址:http://fex.ba ...
- 微信JSSDK多图片上传并且解决IOS系统上传一直加载的问题
微信多图片上传必须挨个上传,也就是不能并行,得串行: 那么我们可以定义一个如下所示的上传函数: var serverIds = []; function uploadImages(localImage ...
- Webuploader 大文件分片上传
百度Webuploader 大文件分片上传(.net接收) 前阵子要做个大文件上传的功能,找来找去发现Webuploader还不错,关于她的介绍我就不再赘述. 动手前,在园子里找到了一篇不错的分片 ...
- 解决WordPress无法上传媒体文件以及无法下载和安装主题与插件的问题
前言: 我的个人博客网站荒原之梦在安装成功WordPress之后本来是可以上传媒体文件,安装主题和插件的,但是后来不知道怎么回事就出了问题:不能上传媒体文件也不能安装主题和插件了.出现这个问题后我尝试 ...
- [转]通过设置nginx的client_max_body_size解决nginx+php上传大文件的问题
转:http://blog.csdn.net/zhengwish/article/details/51602059 通过设置nginx的client_max_body_size解决nginx+php上 ...
- 通过设置nginx的client_max_body_size解决nginx+php上传大文件的问题
通过设置nginx的client_max_body_size解决nginx+php上传大文件的问题:用nginx来做webserver的时,上传大文件时需要特别注意client_max_body_si ...
随机推荐
- MySQL常用知识
1.MySQL常用引擎有哪些? A:MySQL常用的引擎有InnoDB.MyISAM.Memory,默认时InnoDB InnoDB:磁盘表,支持事务,支持行级锁,B+Tree索引 优点:具有良好的A ...
- Python的扩展接口[3] -> Matlab引擎 -> 使用 Python 调用 Matlab 程序
Python - Matlab 目录 Python-Matlab 引擎 Python-Matlab 数组 Python-Matlab 基本操作 Python-Matlab 调用 m 文件 Matlab ...
- VS2015快捷键及常用功能
写下这些快捷键的操作,并不是全部记住,记住常用的,然后其他的来查询就好了. 1.回到上一个光标位置/前进到下一个光标位置 1)回到上一个光标位置:使用组合键“Ctrl + -”; 2)前进到下一个光标 ...
- 【bzoj1875】【JZYZOJ1354】[SDOI2009]HH去散步 矩阵快速幂 点边转换
http://172.20.6.3/Problem_Show.asp?id=1354 http://www.lydsy.com/JudgeOnline/problem.php?id=1875 题意: ...
- lightoj 1306 - Solutions to an Equation 扩展的欧几里得
思路:看题就知道用扩展的欧几里得算法做!!! 首先我们可以求出ax+by=gcd(a,b)=g的一个组解(x0,y0).而要使ax+by=c有解,必须有c%g==0. 继而可以得到ax+by=c的一个 ...
- bzoj1004 purfer 序列
之前没不知道这个数列. 一个purfer序列与一棵树一一对应. 长度为n的purfer的集合: A = { s | s is a sequence and a∈[1,len(s)+2] 一个直接的结论 ...
- OpenAPI安全防护
1,开放API可能存在的数据安全问题 (1)数据窃取 通常体现为:钓鱼网站,拦截,伪装,截包 (2)数据篡改 中间被拦截,以代理的方式拦截数据,修改数据 (3)数据泄露 爬虫抓取核心数据 2,解决数据 ...
- hihocoder 1522 : F1 Score
题目链接 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi和他的小伙伴们一起写了很多代码.时间一久有些代码究竟是不是自己写的,小Hi也分辨不出来了. 于是他实现 ...
- CountDownLatch CyclicBarrier Semaphore 比较
document CountDownLatch A synchronization aid that allows one or more threads to wait until a set of ...
- layoutit note
Head: JavaScript -> Navbar Menu: JavaScript -> Collapse Compnents -> Panels Compnents -> ...