plupload文件上传插件
一 资源文档
二 基本使用
三 可能遇到的问题
一 资源文档
Git仓库地址:https://github.com/moxiecode/plupload
一个中文速查:http://www.cnblogs.com/2050/p/3913184.html
可能有用的demo: http://chaping.github.io/plupload/demo/index.html
二 基本使用
html:
<ul id="filelist"></ul>
<br />
<div id="container">
<a id="browse" href="javascript:;">[Browse...]</a>
<a id="start-upload" href="javascript:;">[Start Upload]</a>
</div>
<br />
<pre id="console"></pre>
js:
<script type="text/javascript">
var uploader = new plupload.Uploader({
browse_button: 'browse',
url: 'upload.php'
}); uploader.init(); uploader.bind('FilesAdded', function(up, files) {
var html = '';
plupload.each(files, function(file) {
html += '<li id="' + file.id + '">' + file.name + ' (' + plupload.formatSize(file.size) + ') <b></b></li>';
});
document.getElementById('filelist').innerHTML += html;
}); uploader.bind('UploadProgress', function(up, file) {
document.getElementById(file.id).getElementsByTagName('b')[0].innerHTML = '<span>' + file.percent + "%</span>";
}); uploader.bind('Error', function(up, err) {
document.getElementById('console').innerHTML += "\nError #" + err.code + ": " + err.message;
}); document.getElementById('start-upload').onclick = function() {
uploader.start();
};
</script>
主要是使用options配置参数,使用内置函数添加方法,使用init()方法初始化uploader。
1 Options( 配置参数)
只有两个option是必须的: browse_button和url,剩下的都是可选的。
browse_button可以是DOM元素本身或者它的id。
url是服务端的fileupload handler
2 Events(各种事件)
常用的事件:
Init:当Plupload初始化完成后触发
PostInit:当Init事件发生后触发
FilesAdded:当文件添加到上传队列后触发
FileUploaded:当队列中的某一个文件上传完成后触发
UploadComplete:当上传队列中所有文件都上传完成后触发
Error:当发生错误时触发
可以根据error code捕捉到各种错误,各种错误码在plupload命名空间上的一些属性都可以找到。
3 Properties(plupload实例属性)
常用的属性:
id: uploader实例的唯一id
state: 整个上传的当前状态,可能是plupload.STARTED 或者 plupload.STOPPED. 可以通过stop/start方法控制. 默认值值STOPPED。
files: 当前上传队列,是一个文件实例的数组。
total:总的上传进度信息。包括多少文件已经上传完成,进度百分比等。
4 Methods(plupload实例方法)
常用的方法:
init()
初始化uploader实例并添加内部事件监听函数。
start()
开始上传队列文件
stop()
停止上传队列文件
5文件对象的属性和方法
在很多事件监听函数中,都会提供文件对象。其中FilesAdded,FilesRemoved和UploadComplete提供的是文件对象的数组,因为plupload允许同时选取多个文件。文件对象的属性包括name(文件名),type(文件类型),size(文件大小等),status(文件状态等)。文件方法包括getNative()(获取原生的文件对象), getSource()(获取mOxie.File 对象),关于oMoxie,后面会说明。
6 plupload命名空间上的一些属性
主要是文件对象的status属性, plupload实例的state属性和各种错误的error code
1)state: STOPPED(1), STARTED(2)
2)status:QUEUED(1),UPLOADING(2), FAILED(4),DONE,(5)
3)error code:
HTTP_ERROR(-200): 发生http网络错误时
FILE_SIZE_ERROR(-600): 当选择的文件太大时
FILE_EXTENSION_ERROR(-601); 当选择的文件类型不符合要求时
FILE_DUPLICATE_ERROR(-602); 当选取了重复的文件而配置中又不允许有重复文件时
IMAGE_DIMENSIONS_ERROR(-702): 当文件大小超过了plupload所能处理的最大值时
三 可能遇到的问题
1 关于ie9 runtimes
Plupload是一个multi-runtime的文件上传API。
runtimes默认值为: "html5,flash,silverlight,html4"。可以在options中配置。
一般情况下,不需要配置该参数,因为Plupload默认会根据你的其他的参数配置来选择最合适的上传方式。如果没有特殊要求的话,Plupload会首先选择html5上传方式,如果浏览器不支持html5,则会使用flash或silverlight,如果前面两者也都不支持,则会使用最传统的html4上传方式。
在ie9浏览器下,不支持flash,需要使用oMxie的polyfill,借助的就是Moxie.swf。需要在options中配置两个option:flash_swf_url和silverlight_xap_url。分别对应flash上传组件的url地址和silverlight上传组件的url地址,如果是相对路径,则相对的是调用Plupload的html文档。
当找不到Moxie.swf文件时,runtimes会fallback到html4。下面两个截图就是找不到文件和找到文件时情况,moxie-shim的class会不同。当ie9下出现moxie-shim-html4,通常是没有找到Moxie.swf文件,会出现ie9的一些兼容性问题,比如浏览图片按钮不好点击或者前端预览图片无法显示等问题。
了解oMxie:https://github.com/moxiecode/moxie/wiki/API
2关于flash跨域请求
在Flash中发起HTTP请求外部网站的资源时会引起Flash的跨域问题。
出现跨域问题时,Flash会先访问对方网站根目录的crossdomain.xml文件。
crossdomain.xml文件可以定义哪些网站有权限访问本网站的资源。
所以如果我们要允许别的网站跨域访问本网的资源需要在根目录下加入crossdomain.xml文件。
<?xml version="1.0"?>
<cross-domain-policy>
<allow-access-from domain="wuage.com" />
</cross-domain-policy>
配置很简单,domain表示允许访问的域名。
plupload文件上传插件的更多相关文章
- 20款最好的jQuery文件上传插件
当它是关于开发网络应用程序和网页的时候,文件上传功能的重要性是不容忽视的.一个文件上传功能可以让你上传所有类型的文件在网站上,包括视频,图像,文件和更多.创建一个文件上传功能,对你的网站是不是很难,有 ...
- 7 款基于 JavaScript/AJAX 的文件上传插件
本文整理了7款基于JavaScript和AJAX的文件上传插件,这些插件基本上都能实现以下功能: 多文件上传 拖拽操作 实时上传进度 自定义上传限制 希望能为你的开发工作带来帮助. 1. jQuer ...
- 7款js文件上传插件
1. jQuery File Upload 具有多文件上传.拖拽.进度条和图像预览功能的文件上传插件,支持跨域.分块.暂停恢复和客户端图像缩放.可与任何服务端平台(如PHP.Python.Ruby ...
- 强大的支持多文件上传的jQuery文件上传插件Uploadify
支持多文件上传的jQuery文件上传插件Uploadify,目前此插件有两种版本即Flash版本和HTML5版本,对于HTML5版本会比较好的支持手机浏览器,避免苹果手机Safari浏览器不支持Fla ...
- jQuery文件上传插件Uploadify(转)
一款基于flash的文件上传,有进度条和支持大文件上传,且可以多文件上传队列. 这款在flash的基础上增加了html5的支持,所以在移动端也可以使用. 由于官方提供的版本是flash免费,html5 ...
- 基于Metronic的Bootstrap开发框架经验总结(5)--Bootstrap文件上传插件File Input的使用
Bootstrap文件上传插件File Input是一个不错的文件上传控件,但是搜索使用到的案例不多,使用的时候,也是一步一个脚印一样摸着石头过河,这个控件在界面呈现上,叫我之前使用过的Uploadi ...
- jQuery文件上传插件jQuery Upload File 有上传进度条
jQuery文件上传插件jQuery Upload File 有上传进度条 jQuery文件上传插件jQuery Upload File,插件使用简单,支持单文件和多文件上传,支持文件拖拽上传,有进度 ...
- 可拖拽和带预览图的jQuery文件上传插件ssi-uploader
插件描述:ssi-uploader是一款带预览图并且可以拖拽文件的jQuery ajax文件上传插件.该文件上传插件支持AJAX,支持多文件上传,可控制上的文件格式和文件大小,提供各种回调函数,使用非 ...
- Bootstrap文件上传插件File Input的使用
基于Metronic的Bootstrap开发框架经验总结(5)--Bootstrap文件上传插件File Input的使用 Bootstrap文件上传插件File Input是一个不错的文件上传控件, ...
随机推荐
- T-SQL存储过程
存储过程(procedure)就是一个函数,完成一段sql代码的封装,实现代码的重用. 优点: 1.比使用DotNet直接写Sql脚本执行少了一块解析编译的过程.效率更快一点点. ...
- 样式布局分享-基于frozen.js的移动OA
最近改造了公司移动OA的样式,改善了显示效果和用户体验,其中用到了腾讯的 frozen.js 框架,在此把布局代码分享给大家,希望大家可以用得上,具体效果如下图. Demo 百度网盘 下载地址 Git ...
- struts 2 debug标签隐藏不显示
struts2 的标签debug在页面中应用,并且struts的配置文件中也设置为开发模式,但是这个标签却被隐藏了,究其原因,是因为页面中body元素生命了class,其样式覆盖了原来的样式. 比如: ...
- 12款令程序员惊叹的CSS3效果库
最新的CSS3都配备了新的特性,来设计创建动画和互动的网页.在本文中,可以找到一些非常优秀的CSS3效果库,来让你的Web设计看起来更加引人注目.还在等什么?让我们一起看起来吧! Animate.cs ...
- 异步消息处理机制——Handler用法
Handler 1. Message Messsge是线程之间传递的消息,它可以在内部携带少量的信息,用于在不同线程之间交换数据,Message的what字段,除此之外还可以使用arg1和arg2字段 ...
- slice,substr,substring
var s = '0123456789'; //slice 遇负数,则此负数值等同于 s.length + (负数) s.slice(3,6); //"345", 从位置3开始 ...
- php cli模式没有加载php.ini
这两天在虚拟机的linux里编译安装了php,同时也把swoole的扩展也编译上了.在/etc/php.ini里加上了extension=swoole.so,但是用php -m 查看加载的模块并没有s ...
- 12行代码 让浏览器崩溃,iPhone重启
<html> <body> <script> var total=""; for (var i=0;i<1000000;i++) { ...
- Gradle templates 的使用
使用gradle 时有一些繁琐的创建工程 使用插件的步骤. 这些步骤可以使用一些gradle的模板来代替. 具体的操作步骤: 安装gradle: Prerequired: Java SDK insta ...
- SQL Server 移动master 数据库
第一步: 告诉SQL Server 下次启动时master数据库的文件在哪里!我想们一定想到了(这样做是不对的,它对master不起作用,第二步开始正确的做法) alter database mast ...