admin管理员组文章数量:1123003
uploadify
介绍
ploadify是JQuery的一个上传插件,支持多文件上传,实现的效果非常不错,带进度显示。
下载
- 前往官网进行下载,但小编发现,各路人马提供的官网全都打不开,在Github下载的文件为uploadifive.js ,小编怎么看这个文件名都觉得是个山寨货,所以小编不推荐这种方式。
- 通过npm下载
npm install --save uploadify
-
小编提供
百度网盘
链接:
提取码:kxey
参数说明
- 属性
{auto:true,//设置为true当选择文件后就直接上传了,为false需要点击上传按钮才上传 buttonClass:"",//按钮样式buttonCursor:"hand",//鼠标指针悬停在按钮上的样子buttonImage:null,//浏览按钮的图片的路径buttonText:"SELECT FILES",//浏览按钮的文本checkExisting:false,//文件上传重复性检查程序,检查即将上传的文件在服务器端是否已存在,存在返回1,不存在返回0debug: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:null,//JSON格式上传每个文件的同时提交到服务器的额外数据,可在’onUploadStart’事件中使用’settings’方法动态设置height:30,//设置浏览按钮的高度 ,默认值itemTemplate:false,//用于设置上传队列的HTML模版,可以使用以下标签:instanceID – Uploadify实例的ID/*fileID – 列队中此文件的ID,或者理解为此任务的IDfileName – 文件的名称fileSize – 当前上传文件的大小插入模版标签时使用格式如:${fileName}*/method:"Post",//提交方式Post或Getmulti:true,//设置为true时可以上传多个文件overrideEvents:null,//设置哪些事件可以被重写,JSON格式,如:’overrideEvents’ : ['onUploadProgress']preventCaching:true,//如果为true,则每次上传文件时自动加上一串随机字符串参数,防止URL缓存影响上传结果progressData:"percentage",//设置上传进度显示方式,percentage显示上传百分比,speed显示上传速度queueID:false,//设置上传队列容器DOM元素的ID,如果为false则自动生成一个队列容器queueSizeLimit:999,//队列最多显示的任务数量,如果选择的文件数量超出此限制,将会出发onSelectError事件。注意此项并非最大文件上传数量,如果要限制最大上传文件数量,应设置uploadLimitremoveCompleted: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对象包含如下属性:
|
onDialogOpen() | 当文件选择对话框弹出时立即出发,但可能在文件选择对话框被关闭之前并不能全部执行 |
onDisable() | 当disable方法禁用Uploadify上传按钮时被调用时触发 |
onEnable() | 当disable方法启用Uploadify上传按钮时被调用时触发 |
onFallback() | 当Uploadify初始化过程中检测到当前浏览器不支持flash时触发 |
onInit() | 首次初始化Uploadify结束时触发 |
onQueueComplete(queueData) | 文件上传队列处理完毕后触发。 queueData对象包含如下属性:
|
onSelect(file) | 选择文件后向队列中添加每个上传任务时都会触发 |
onSelectError(file, errorCode, errorMsg) | 选择文件后向队列中添加每个上传任务时如果失败都会触发。 file – 文件对象 errorCode – 错误代码如下:
errorMsg – 错误提示,可通过’this.queueData.errorMsg’定制 |
onSWFReady() | Flash文件载入成功后触发 |
onUploadComplete(file) | 每个文件上传完毕后无论成功与否都会触发 |
onUploadError(file, errorCode, errorMsg, errorString) | 文件上传出错时触发,参数由服务端程序返回 |
nUploadProgress(file, bytesUploaded, bytesTotal, totalBytesUploaded, totalBytesTotal) | 处理上传队列的过程中会多次触发此事件,每当任务状态有更新时都会触发
|
onUploadStart(file) | 当文件即将开始上传时立即触发 |
onUploadSuccess(file, data, response) | 当文件上传成功时触发
|
- 方法
名称 | 说明 | 示例 |
cancel(fileID, suppressEvent) | 取消队列中的任务,不管此任务是否已经开始上传
|
|
destroy() | 销毁Uploadify实例并将文件上传按钮恢复到原始状态 |
|
disable(setDisabled) | 禁用或启用文件浏览按钮 setDisabled – 设置为true表示禁用,false为启用 |
|
settings(name, value, resetObjects) | 获取或设置Uploadify实例参数
|
|
stop() | 停止当前正在上传的任务 |
|
upload(fileID) | 立即上传指定的文件,如果fileID为’*'表示上传所有文件,要指定上传多个文件,则将每个文件的fileID作为一个参数 |
|
完整示例:
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title><link rel="stylesheet" href="uploadify/uploadify.css">
</head>
<body><h1>Uploadify Demo</h1><form><div id="queue"></div><input id="file_upload" name="file_upload" type="file" multiple="true"></form><h4>操作:</h4><a href="javascript:$('#file_upload').uploadify('upload', '*');">开始上传</a>|<a href="javascript:$('#file_upload').uploadify('cancel', '*');">清除队列</a>|<a href="javascript:$('#file_upload').uploadify('destroy');">销毁上传</a> |<a href="javascript:$('#file_upload').uploadify('disable', true);">禁用上传</a>|<a href="javascript:$('#file_upload').uploadify('disable', false);">激活上传</a>|<a href="javascript:$('#file_upload').uploadify('stop');">停止上传</a> |<a href="changeBtnText();">变换按钮</a> |<h4>大小:</h4><div id='progress'></div><script src="js/jquery.min.js"></script><script src="uploadify/jquery.uploadify.v2.1.4.js"></script><script src="uploadify/swfobject.js"></script><script type="text/javascript">$(function() {$('#file_upload').uploadify({'debug' : false,'auto' : true, //是否自动上传,'buttonClass' : 'haha', //按钮辅助class'buttonText' : '上传图片', //按钮文字'height' : 30, //按钮高度'width' : 100, //按钮宽度'checkExisting' : 'check-exists.php',//是否检测图片存在,不检测:false'fileObjName' : 'files', //默认 Filedata, $_FILES控件名称'fileSizeLimit' : '1024KB', //文件大小限制 0为无限制 默认KB'fileTypeDesc' : 'All Files', //图片选择描述'fileTypeExts' : '*.gif; *.jpg; *.png',//文件后缀限制 默认:'*.*''formData' : {'someKey' : 'someValue','someOtherKey' : 1},//传输数据JSON格式// 'formData' :{ 'albumid':$("#albumid").val() },//'overrideEvents' : ['onUploadProgress'], // The progress will not be updated//'progressData' : 'speed', //默认percentage 进度显示方式'queueID' : 'queue', //默认队列ID'queueSizeLimit' : 20, //一个队列上传文件数限制'removeCompleted' : true, //完成时是否清除队列 默认true'removeTimeout' : 3, //完成时清除队列显示秒数,默认3秒'requeueErrors' : false, //队列上传出错,是否继续回滚队列'successTimeout' : 5, //上传超时'uploadLimit' : 99, //允许上传的最多张数'swf' : '/uploadify/uploadify.swf', //swfUpload'uploader' : 'uploadify.php', //服务器端脚本//修改formData数据'onUploadStart' : function(file) {//$("#file_upload").uploadify("settings", "someOtherKey", 2);},'onUploadStart' : function(file) {// $("#perpic").uploadify("settings","formData",{"albumid":$("#albumid").val()});},//删除时触发'onCancel' : function(file) {//alert('The file ' + file.name + '--' + file.size + ' was cancelled.');},//清除队列'onClearQueue' : function(queueItemCount) {//alert(queueItemCount + ' file(s) were removed from the queue');},//调用destroy是触发'onDestroy' : function() {alert('我被销毁了');},//每次初始化一个队列是触发'onInit' : function(instance) {//alert('The queue ID is ' + instance.settings.queueID);},//上传成功'onUploadSuccess' : function(file, data,response) {//alert(file.name + ' | ' + response + ':' + data);},//上传错误'onUploadError' : function(file, errorCode,errorMsg, errorString) {//alert('The file ' + file.name + ' could not be uploaded: ' + errorString);},//上传汇总'onUploadProgress' : function(file,bytesUploaded, bytesTotal,totalBytesUploaded, totalBytesTotal) {$('#progress').html(totalBytesUploaded+ ' bytes uploaded of '+ totalBytesTotal+ ' bytes.');},//上传完成'onUploadComplete' : function(file) {//alert('The file ' + file.name + ' finished processing.');}});});//变换按钮function changeBtnText() {$('#file_upload').uploadify('settings', 'buttonText', '继续上传');}//返回按钮function returnBtnText() {alert('The button says '+ $('#file_upload').uploadify('settings', 'buttonText'));}</script>
</body>
</html>
注:文件上传需要后台服务台的支持,故小编在此只贴出前端代码,毕竟,后台不归小编管呀~
本文标签: uploadify
版权声明:本文标题:uploadify 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1687872280a151734.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论