使用Uploadify(UploadiFive)多文件上传控件遇到的坑
最近项目中需要实现多文件上传功能,于是结合需求最终选择了Uploadify这一款控件来实现。相比其他控件,Uploadify具有简洁的界面,功能API基本可以解决大多数需求,又是基于jquery的,配置起来相对容易。但是不用不知道,一用起来发现坑还是蛮多了,相信大部分用过的人都会遇到,下面就来分享下我的填坑过程:
根据官网文档配置好我所需要的前端配置项,再让后台同事把对应的后台配置搞定后,在chrome下尝试了下一些ok。心想这样就大工告成了?呵呵。。。那么问题来了。
一、使用Uploadify
(1)、chrome报错
按F12打开调试面板刷新页面后会显示如下错误信息:
这是啥?请求了3次失败了2次最后成功了1次,后来发现只有chrome下会报这个错误,大概是因为chrome对于swf文件的安全性措施导致的,因为不影响功能,暂时没去管它。
(2)、发现火狐上失效
当我打开火狐的时候,突然发现按钮失效,就是一个type='file'的按钮,只能单文件上传,原因很简单,那便是火狐检测不到我的flash。而Uploadify是一款利用flash来实现多文件上传功能,这对没有安装flash的用户来说无疑根本没法用。
好吧,但是我选择先忍了,因为开发的是一款后台应用,给自己人用的,所以大不了让他们安装下flash,使用chrome浏览器来访问好了。
(3)、文件上传完毕后会自动消失
根据项目需求,文件上传完毕后仍然留在页面上,并显示相应信息。然而Uploadify默认上传成功后会自动删除页面上的文件。这个问题解决起来很简单,有相应的API来实现:
$("#file_upload").uploadify({
'removeCompleted' : false,
'swf' : '/uploadify/uploadify.swf',
'uploader' : '/uploadify/uploadify.php'
});
将removeCompleted设置为false即可。如果需要将上传失败的文件也保留在页面上,可以设置'removeTimeout' 的值无限制大,这样不用设置removeCompleted也行。
(4)上传完毕文件无法清除
如果保留上传完毕文件,那么呵呵了,文件不会因为你触发cancel方法而清除,即使页面上清除了,等你再选择已经上传完的文件后,会显示提示你文件已存在,是否覆盖的弹框。
百度许久后发现这是一个公认的bug,暂时没有很好的解决方案。于是我再也忍不住了,果断舍弃flash版本的Uploadify,换用其html5版本的UploadiFive。
二、使用UploadiFive
然而自从换了UploadiFive后,心情果断舒畅了很多,之前(1)(2)(3)(4)中的问题荡然无存了,心想这不是逼我们购买付费版嘛。。。
但是UploadiFive却抛弃了Uploadify中的一些功能:
(1)无未上传文件重复提示
Uploadify中添加同名文件会提示是否覆盖,而UploadiFive却是直接覆盖,没有提示信息。可以接受。
(2)上传完毕后进度条消失
Uploadify中上传完毕会默认保留进度条并显示100%,前提设置removeCompleted为false,而UploadiFive中上传完毕后进度条自动消失。勉强接受。
(3)无自动检测文件大小功能
Uploadify中选择文件加入队列后,会在文件名后自动加上该文件的大小,而UploadiFive却没有该功能,这不是故意为难我们吗......假装接受不了。于是开始研究其源代码。
1个多小时后解决了这个问题。
下面是解决方案:
首先UploadiFive的js文件是压缩过的,最好还原其源代码,在sublime text3中安装HTML-CSS-JS Prettify插件后利用快捷键shift+alt+H 可快速实现js格式化。
格式化后找到jquery.uploadifive.js中的$data.addQueueItem方法,在
file.queueItem.find('.filename').html(fileName)后添加
/*以下添加文件大小检测*/
var fileSize = Math.round(file.size / 1024);
var suffix = 'KB';
if (fileSize > 1000) {
fileSize = Math.round(fileSize / 1000);
suffix = 'MB';
}
var fileSizeParts = fileSize.toString().split('.');
fileSize = fileSizeParts[0];
if (fileSizeParts.length > 1) {
fileSize += '.' + fileSizeParts[1].substr(0, 2);
}
fileSize += suffix;
file.queueItem.find('.filesize').html('('+fileSize+')');
/*以上添加文件大小检测*/
同时找到$data.queueItem,在其中添加<span class="filesize"></span>
if (settings.itemTemplate == false) {
$data.queueItem = $('<div class="uploadifive-queue-item">\
<a class="close" href="#">X</a>\
<div><span class="filename"></span><span class="filesize"></span><span class="fileinfo"></span></div>\
<div class="progress">\
<div class="progress-bar"></div>\
</div>\
</div>');
} else {
$data.queueItem = $(settings.itemTemplate);
}
这样就ok了,修改后的源码我放到了我的github上,需要的童鞋请访问:https://github.com/luozhihao/uploadifive
以上便是我的填坑过程,相信很多人都会遇到,特此分享!
同时在这里推荐另外两款实用的多文件上传控件,根据项目需求使用:
a、jQuery File Upload 官网:http://blueimp.github.com/jQuery-File-Upload/
b、百度的Web Uploader 官网:http://fex.baidu.com/webuploader/
使用Uploadify(UploadiFive)多文件上传控件遇到的坑的更多相关文章
- jquery文件上传控件 Uploadify
(转自 http://www.cnblogs.com/mofish/archive/2012/11/30/2796698.html) 基于jquery的文件上传控件,支持ajax无刷新上传,多个文件同 ...
- jquery文件上传控件 Uploadify 问题记录
Uploadify v3.2.1 首先引用下面的文件 <!--上传控件 uploadify--> <script type="text/javascript" s ...
- jquery文件上传控件 Uploadify 可以和ajax交互
http://www.cnblogs.com/mofish/archive/2012/11/30/2796698.html 原网址 基于jquery的文件上传控件,支持ajax无刷新上传,多个文件同 ...
- jquery文件上传控件 Uploadify(转)
原文:http://www.cnblogs.com/mofish/archive/2012/11/30/2796698.html 基于jquery的文件上传控件,支持ajax无刷新上传,多个文件同时上 ...
- 在WebBrowser中通过模拟键盘鼠标操控网页中的文件上传控件(转)
引言 这两天沉迷了Google SketchUp,刚刚玩够,一时兴起,研究了一下WebBrowser. 我在<WebBrowser控件使用技巧分享>一文中曾谈到过“我现在可以通过WebBr ...
- 因用了NeatUpload大文件上传控件而导致Nonfile portion > 4194304 bytes错误的解决方法
今天遇到一个问题,就是“NeatUpload大文件上传控件而导致Nonfile portion > 4194304 bytes错误”,百度后发现了一个解决方法,跟大家分享下: NeatUploa ...
- 对FileUpload文件上传控件的一些使用方法说明
//创建时间:2014-03-12 //创建人:幽林孤狼 //说明:FileUpload文件上传控件使用说明(只是部分)已共享学习为主 //可以上传图片,txt文档.doc,wps,还有音频文件,视屏 ...
- ***文件上传控件bootstrap-fileinput的使用和参数配置说明
特别注意: 引入所需文件后页面刷新查看样式奇怪,浏览器提示错误等,可能是因为js.css文件的引用顺序问题,zh.js需要在fileinput.js后面引入.bootstrap最好在filein ...
- 符合BME风格的弹窗\菜单\表格\文件上传控件
1.弹窗 2.菜单 3.表格 4.文件上传控件 笔记补充......
随机推荐
- git 本地库提交至远程服务器
1. git init 2. git add . 3. git commit -am "###" -------以上3步只是本地提交 4.git remote add o ...
- java 多线程(ThreadPoolExecutor (补充))
import java.util.concurrent.ArrayBlockingQueue; import java.util.concurrent.ThreadPoolExecutor; impo ...
- 微软颜龄Windows Phone版开发小记
随着微软颜龄中文网cn.how-old.net的上线,她也顺势来到了3大移动平台. 用户在微软颜龄这一应用中选择一张包含若干人脸的照片,就可以通过云计算得到他们的性别和年龄. 今天我们就和大家分享一下 ...
- C#可扩展编程之MEF学习笔记(四):见证奇迹的时刻
前面三篇讲了MEF的基础和基本到导入导出方法,下面就是见证MEF真正魅力所在的时刻.如果没有看过前面的文章,请到我的博客首页查看. 前面我们都是在一个项目中写了一个类来测试的,但实际开发中,我们往往要 ...
- 手把手搭建WAMP+PHP+SVN开发环境
一:WAMP 这款软件在安装的过程中就已经把Apache.MySQL.PHP继承好了,而且也做好了相应的配置,除此之外,还加上了SQLitemanager和Phpmyadmin,省去了很多复杂的配置过 ...
- 强大的Sublime编辑器
Sublime是一款功能非常强大的轻量级的代码及文本编辑工具,有关它的介绍和下载可以从官网http://www.sublimetext.com获取.尽管Sublime并非是一款完全免费的IDE开发工具 ...
- webservice3
什么是bottom up 什么是top down 通过浏览器访问如 http://localhost:8080/HelloWS/services/HelloWSsss?wsdl 获取的 wsdl, ...
- Java-条件语句、循环语句练习
题目一:一张纸的厚度大约是0.08mm,对折多少次之后能达到珠穆朗玛峰的高度(8848.13米)? double height=0.08; for(int i=1;i>0;i++) { heig ...
- Atitit.加密算法ati Aes的框架设计v2.2
Atitit.加密算法ati Aes的框架设计v2.2 版本进化1 V2.2 add def decode key api1 v1版本1 Aes的历史2 Atitit.加密算法 des aes ...
- java基础,继承类题目:编写一个Java应用程序,该程序包括3个类:Monkey类、People类和主类 E
21.编写一个Java应用程序,该程序包括3个类:Monkey类.People类和主类 E.要求: (1) Monkey类中有个构造方法:Monkey (String s),并且有个public vo ...