详解jQuery uploadify文件上传插件的使用方法


Posted in Javascript onDecember 16, 2016

uploadify这个插件是基于js里面的jquery库写的。结合了ajax和flash,实现了这个多线程上传的功能。

现在最新版为3.2.1。

在线实例

实例中用到的php文件UploaderDemo.php请在页面下方下载

引入文件

  • <link rel="stylesheet" type="text/css" href="uploadify.css" />
  • <script type="text/javascript" src="jquery.min.js"></script>
  • <script type="text/javascript" src="jquery.uploadify.js"></script>

使用方法

<form>
 <div id="queue"></div>
 <input id="file_upload" name="file_upload" type="file" multiple="true">
 </form>
 <div id="uploadfiles"></div> 
<div id="fileQueue" style="clear:both"></div>
<script type="text/javascript">
var timestamp = new Date().getTime();
var token = Math.floor(Math.random() * 1000) + timestamp;
$(function() {
 $('#file_upload').uploadify({
 'buttonText': '选择文件..',
 'fileObjName': 'simplefile',
 'method': 'post',
 'multi': true,
 'queueID': 'fileQueue',
 //'uploadLimit': 2,
 'fileTypeExts': '*.gif;*.png;*.jpg;*.bmp;*.jpeg;',
 'buttonImage': '/static/js/uploadify/select.png',
 'formData': {
 'timestamp': timestamp,
 'token': token
 },
 'swf': '/static/js/uploadify/uploadify.swf',
 'uploader': '/static/php/UploaderDemo.php',
 'onUploadStart': function() {
 $imgHtml = '<img class="upload_load" src="/static/images/upload.gif" align="absmiddle" />';
 $('#uploadfiles').append($imgHtml);
 },
 'onUploadSuccess': function(file, data, response) {
 $('.upload_load').remove();
 var json = $.parseJSON(data);
 if (json.state == 'success') {
 $imgHtml = '<span id="file_' + json.file_id + '">';
 $imgHtml += '<a href="' + json.file + '" target="_blank">';
 $imgHtml += '<img src="' + json.file + '" width="100" height="100" align="absmiddle"/>';
 $imgHtml += '</a>';
 $imgHtml += '<a href="javascript:uploadifyRemove("' + json.file + '")">删除</a>';
 $imgHtml += '</span>';
 $($imgHtml).appendTo('#uploadfiles');
 } else {
 alert(json.message);
 }
 },
 'onQueueComplete': function() {
 $('.upload_load').remove();
 }
 });
}); 
</script>

参数说明

一、属性
属性名称 默认值 说明
auto true 设置为true当选择文件后就直接上传了,为false需要点击上传按钮才上传 。
buttonClass 按钮样式
buttonCursor ‘hand' 鼠标指针悬停在按钮上的样子
buttonImage null 浏览按钮的图片的路径 。
buttonText ‘SELECT FILES' 浏览按钮的文本。
checkExisting false 文件上传重复性检查程序,检查即将上传的文件在服务器端是否已存在,存在返回1,不存在返回0
debug false 如果设置为true则表示启用SWFUpload的调试模式
fileObjName ‘Filedata' 文件上传对象的名称,如果命名为'the_files',PHP程序可以用$_FILES['the_files']来处理上传的文件对象。
fileSizeLimit 0 上传文件的大小限制 ,如果为整数型则表示以KB为单位的大小,如果是字符串,则可以使用(B, KB, MB, or GB)为单位,比如'2MB'; 如果设置为0则表示无限制
fileTypeDesc ‘All Files' 这个属性值必须设置fileTypeExts属性后才有效,用来设置选择文件对话框中的提示文本,如设置fileTypeDesc为“请选择rar doc pdf文件”
fileTypeExts ‘*.*' 设置可以选择的文件的类型,格式如:'*.doc;*.pdf;*.rar' 。
formData   JSON格式上传每个文件的同时提交到服务器的额外数据,可在'onUploadStart'事件中使用'settings'方法动态设置。
height 30 设置浏览按钮的高度 ,默认值
itemTemplate false 用于设置上传队列的HTML模版,可以使用以下标签: instanceID ? Uploadify实例的ID fileID ? 列队中此文件的ID,或者理解为此任务的ID fileName ? 文件的名称 fileSize ? 当前上传文件的大小 插入模版标签时使用格式如:${fileName}
method Post 提交方式Post或Get
multi true 设置为true时可以上传多个文件。
overrideEvents   设置哪些事件可以被重写,JSON格式,如:'overrideEvents' : ['onUploadProgress']
preventCaching true 如果为true,则每次上传文件时自动加上一串随机字符串参数,防止URL缓存影响上传结果
progressData ‘percentage' 设置上传进度显示方式,percentage显示上传百分比,speed显示上传速度
queueID false 设置上传队列容器DOM元素的ID,如果为false则自动生成一个队列容器。
queueSizeLimit 999 队列最多显示的任务数量,如果选择的文件数量超出此限制,将会出发onSelectError事件。 注意此项并非最大文件上传数量,如果要限制最大上传文件数量,应设置uploadLimit。
removeCompleted true 是否自动将已完成任务从队列中删除,如果设置为false则会一直保留此任务显示。
removeTimeout 3 如果设置了任务完成后自动从队列中移除,则可以规定从完成到被移除的时间间隔。
requeueErrors false 如果设置为true,则单个任务上传失败后将返回错误,并重新加入任务队列上传。
successTimeout 30 文件上传成功后服务端应返回成功标志,此项设置返回结果的超时时间
swf ‘uploadify.swf' uploadify.swf 文件的相对路径。
uploader uploadify.php 后台处理程序的相对路径。
uploadLimit 999 最大上传文件数量,如果达到或超出此限制将会触发onUploadError事件。
width 120 设置文件浏览按钮的宽度。

二、事件
事件名称 说明
onCancel(file) 当点击文件队列中文件的关闭按钮或点击取消上传时触发,file参数为被取消上传的文件对象
onClearQueue(queueItemCount) 当调用函数cancel方法时触发,queueItemCount参数为被取消上传的文件数量。
onDestroy() 当destory方法被调用时触发
onDialogClose(queueData) 当文件浏览框关闭时触发,如果将此事件被重写,则当向队列添加文件上传出错时不会弹出错误消息提示。 queueData对象包含如下属性: filesSelected 文件选择对话框中共选择了多少个文件 filesQueued 已经向队列中添加了多少个文件 filesReplaced 已经向队列中替换了多少个文件 filesCancelled 取消了多少个文件 filesErrored 出错了多少个文件
onDialogOpen() 当文件选择对话框弹出时立即出发,但可能在文件选择对话框被关闭之前并不能全部执行。
onDisable() 当disable方法禁用Uploadify上传按钮时被调用时触发。
onEnable() 当disable方法启用Uploadify上传按钮时被调用时触发。
onFallback() 当Uploadify初始化过程中检测到当前浏览器不支持flash时触发。
onInit() 首次初始化Uploadify结束时触发。
onQueueComplete(queueData) 文件上传队列处理完毕后触发。 queueData对象包含如下属性: uploadsSuccessful ? 上传成功的文件数量 uploadsErrored ? 上传失败的文件数量
onSelect(file) 选择文件后向队列中添加每个上传任务时都会触发。
onSelectError(file, errorCode, errorMsg) 选择文件后向队列中添加每个上传任务时如果失败都会触发。 file ? 文件对象 errorCode ? 错误代码如下: QUEUE_LIMIT_EXCEEDED ? 任务数量超出队列限制; FILE_EXCEEDS_SIZE_LIMIT ? 文件大小超出限制; ZERO_BYTE_FILE ? 文件大小为0 INVALID_FILETYPE ? 文件类型不符合要求 errorMsg ? 错误提示,可通过'this.queueData.errorMsg'定制
onSWFReady() Flash文件载入成功后触发。
onUploadComplete(file) 每个文件上传完毕后无论成功与否都会触发。
onUploadError(file, errorCode, errorMsg, errorString) 文件上传出错时触发,参数由服务端程序返回。
onUploadProgress(file, bytesUploaded, bytesTotal, totalBytesUploaded, totalBytesTotal) 处理上传队列的过程中会多次触发此事件,每当任务状态有更新时都会触发。 file ? 文件对象 bytesUploaded ? 已上传的字节数 bytesTotal ? 文件总字节数 totalBytesUploaded ? 当前任务队列中全部文件已上传的总字节数 totalBytesTotal ? 当前任务队列中全部文件的总字节数
onUploadStart(file) 当文件即将开始上传时立即触发
onUploadSuccess(file, data, response) 当文件上传成功时触发 file ? 文件对象 data ? 服务端输出返回的信息 response ? 有输出时为true,如果无响应为false,如果返回的是false,当超过successTimeout设置的时间后假定为true

三、方法
方法名称 说明 应用举例
cancel(fileID, suppressEvent) 取消队列中的任务,不管此任务是否已经开始上传 fileID ? 要取消的文件ID,如果为空则取消队列中第一个任务,如果为'*'则取消所有任务 suppressEvent ? 是否阻止触发onUploadCancel事件,当清空队列时非常实用。 取消第一个 清空队列 开始上传所有任务
destroy() 销毁Uploadify实例并将文件上传按钮恢复到原始状态 销毁Uploadify实例
disable(setDisabled) 禁用或启用文件浏览按钮 setDisabled ? 设置为true表示禁用,false为启用 禁用按钮 启用按钮
settings(name, value, resetObjects) 获取或设置Uploadify实例参数 name ? 属性名称,如果只提供属性名称则表示获取其值 value ? 属性值 resetObjects ? 设置为true时,更新postData对象将清空现有的值。否则,新的值将被添加到其末尾。 $(‘#file_upload').uploadify(‘settings','buttonText','BROWSE'); $(‘#file_upload').uploadify(‘settings','buttonText'));
stop() 停止当前正在上传的任务 开始上传 停止上传
upload(fileID) 立即上传指定的文件,如果fileID为'*'表示上传所有文件,要指定上传多个文件,则将每个文件的fileID作为一个参数 开始上传所有文

文件UploaderDemo.php下载

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
JavaScript 利用Cookie记录用户登录信息
Dec 08 Javascript
GWT中复制到剪贴板 js+flash实现复制 兼容性比较好
Mar 07 Javascript
Javascript实现滑块滑动改变值的实现代码
Apr 12 Javascript
jQuery对html元素取值与赋值的方法
Nov 20 Javascript
php利用curl获取远程图片实现方法
Oct 26 Javascript
基于jQuey实现鼠标滑过变色(整行变色)
Dec 07 Javascript
Bootstrap Validator 表单验证
Jul 25 Javascript
JS 事件绑定、事件监听、事件委托详细介绍
Sep 28 Javascript
浅谈在不使用ssr的情况下解决Vue单页面SEO问题(2)
Nov 08 Javascript
jQuery实现侧边栏隐藏与显示的方法详解
Dec 22 jQuery
小程序点餐界面添加购物车左右摆动动画
Sep 23 Javascript
js实现随机点名功能
Dec 23 Javascript
JS搜狐面试题分析
Dec 16 #Javascript
JS重载实现方法分析
Dec 16 #Javascript
概述一个页面从输入URL到页面加载完的过程
Dec 16 #Javascript
详解MVC如何使用开源分页插件(shenniu.pager.js)
Dec 16 #Javascript
js继承实现方法详解
Dec 16 #Javascript
详解jQuery简单的表格应用
Dec 16 #Javascript
JS中parseInt()和map()用法分析
Dec 16 #Javascript
You might like
IIS下PHP连接数据库提示mysql undefined function mysql_connect()
2010/06/04 PHP
php判断两个浮点数是否相等的方法
2015/03/14 PHP
Yii框架引用插件和ckeditor中body与P标签去除的方法
2017/01/19 PHP
PHP实现的一致性Hash算法详解【分布式算法】
2018/03/31 PHP
Jquery+WebService 校验账号是否已被注册的代码
2010/07/12 Javascript
div浮层,滚动条移动,位置保持不变的4种方法汇总
2013/12/11 Javascript
jQuery选择器源码解读(六):Sizzle选择器匹配逻辑分析
2015/03/31 Javascript
教你如何在Node.js中使用jQuery
2016/08/28 Javascript
JS基于面向对象实现的多个倒计时器功能示例
2017/02/28 Javascript
浅谈angular.copy() 深拷贝
2017/09/14 Javascript
详解如何将 Vue-cli 改造成支持多页面的 history 模式
2017/11/20 Javascript
微信小程序实现添加手机联系人功能示例
2017/11/30 Javascript
nodejs express配置自签名https服务器的方法
2018/05/22 NodeJs
Vue父子组件双向绑定传值的实现方法
2018/07/31 Javascript
javascript数据结构之多叉树经典操作示例【创建、添加、遍历、移除等】
2018/08/01 Javascript
微信小程序canvas.drawImage完全显示图片问题的解决
2018/11/30 Javascript
Vue递归组件+Vuex开发树形组件Tree--递归组件的简单实现
2019/04/01 Javascript
在Django同1个页面中的多表单处理详解
2017/01/25 Python
python使用scrapy发送post请求的坑
2018/09/04 Python
python 文件查找及内容匹配方法
2018/10/25 Python
linux环境中没有网络怎么下载python
2019/07/07 Python
Python企业编码生成系统之系统主要函数设计详解
2019/07/26 Python
python实现爬虫抓取小说功能示例【抓取金庸小说】
2019/08/09 Python
python爬虫 urllib模块反爬虫机制UA详解
2019/08/20 Python
django有哪些好处和优点
2020/09/01 Python
Python使用pickle进行序列化和反序列化的示例代码
2020/09/22 Python
python自动打开浏览器下载zip并提取内容写入excel
2021/01/04 Python
python 可视化库PyG2Plot的使用
2021/01/21 Python
MySQL面试题目集锦
2016/04/14 面试题
企业总经理职责
2014/02/02 职场文书
面试通知邮件
2015/04/20 职场文书
可可西里观后感
2015/06/08 职场文书
安全知识竞赛主持词
2015/06/30 职场文书
婚宴新娘致辞
2015/07/28 职场文书
SQL Server数据定义——模式与基本表操作
2021/04/05 SQL Server
Vue.js中v-bind指令的用法介绍
2022/03/13 Vue.js