功能强大的文件上传插件带上传进度-WebUploader
WebUploader是由Baidu WebFE(FEX)团队开发的一个以HTML5/FLASH构建的现代文件上传组件。在现代的浏览器里面能充分发挥HTML5的优势,同时又不摒弃主流IE浏览器,沿用老的FLASH运行时,兼容PC和移动端。它最大的特点是采用大文件分片并发上传,极大的提高了文件上传效率。touchend略要处理下。功能强大的文件上传插件带上传进度 ,有兴趣请直接下载源码拿去用。
我们首先将css和相关js文件加载。然后我们需要准备一个按钮#imgPicker,和一个用来存放添加的文件信息列表的容器#fileList,在body中加入如下代码:
-
首先js创建Web Uploader实例:
-
-
var uploader = WebUploader.create({
-
auto: true, // 选完文件后,是否自动上传
-
swf: 'js/Uploader.swf', // swf文件路径
-
server: 'upload.php', // 文件接收服务端
-
pick: '#imgPicker', // 选择文件的按钮。可选
-
// 只允许选择图片文件。
-
accept: {
-
title: 'Images',
-
extensions: 'gif,jpg,jpeg,bmp,png',
-
mimeTypes: 'image/*'
-
}
-
});
-
-
-
uploader.on( 'fileQueued', function( file ) {
-
var $list = $("#fileList"),
-
$li = $(
-
'<div id="' + file.id + '" class="file-item thumbnail">' +
-
'<img>' +
-
'<div class="info">' + file.name + '</div>' +
-
'</div>'
-
),
-
$img = $li.find('img');
-
-
-
// $list为容器jQuery实例
-
$list.append( $li );
-
-
// 创建缩略图
-
uploader.makeThumb( file, function( error, src ) {
-
if ( error ) {
-
$img.replaceWith('<span>不能预览</span>');
-
return;
-
}
-
-
$img.attr( 'src', src );
-
}, 100, 100 ); //100x100为缩略图尺寸
-
});
-
// 文件上传过程中创建进度条实时显示。
-
uploader.on( 'uploadProgress', function( file, percentage ) {
-
var $li = $( '#'+file.id ),
-
$percent = $li.find('.progress span');
-
-
// 避免重复创建
-
if ( !$percent.length ) {
-
$percent = $('<p class="progress"><span></span></p>')
-
.appendTo( $li )
-
.find('span');
-
}
-
-
$percent.css( 'width', percentage * 100 + '%' );
-
});
-
-
// 文件上传成功,给item添加成功class, 用样式标记上传成功。
-
uploader.on( 'uploadSuccess', function( file, res ) {
-
console.log(res.filePath);//这里可以得到上传后的文件路径
-
$( '#'+file.id ).addClass('upload-state-done');
-
});
-
-
// 文件上传失败,显示上传出错。
-
uploader.on( 'uploadError', function( file ) {
-
var $li = $( '#'+file.id ),
-
$error = $li.find('div.error');
-
-
// 避免重复创建
-
if ( !$error.length ) {
-
$error = $('<div class="error"></div>').appendTo( $li );
-
}
-
-
$error.text('上传失败');
-
});
-
-
// 完成上传完了,成功或者失败,先删除进度条。
-
uploader.on( 'uploadComplete', function( file ) {
-
$( '#'+file.id ).find('.progress').remove();
-
});
-
.prev{left: 20px}
-
.next{right: 20px}
-
PHP处理文件上传
-
-
upload.php接收上传数据,将上传的文件保存到服务器相关目录,并将上传结果告知前端上传组件。
-
-
这里值得一提的是,如果设置了大文件分片上传,PHP将每次上传的小文件片临时保存,等最后文件片全部接收完毕后再将这些临时文件片组合,成为一个完整的大文件。
-
-
webuploader的分片上传是把文件分成若干份,然后向你定义的文件接收端post数据,如果上传的文件大于分片的尺寸,就会进行分片,然后会在post的数据中添加两个form元素chunk和chunks,前者标示当前分片在上传分片中的顺序(从0开始),后者代表总分片数。
-
-
关于upload.php中的代码,这里就不贴出来了,大家可以下载源码来学习。
-
-
http://c7.gg/fw4sn
功能强大的文件上传插件带上传进度-WebUploader的更多相关文章
- 插件介绍 :cropper是一款使用简单且功能强大的图片剪裁jQuery插件。
简要教程 cropper是一款使用简单且功能强大的图片剪裁jQuery插件.该图片剪裁插件支持图片放大缩小,支持鼠标滚轮操作,支持图片旋转,支持触摸屏设备,支持canvas,并且支持跨浏览器使用. c ...
- jQuery功能强大的图片查看器插件
简要教程 viewer是一款功能强大的图片查看器jQuery插件.它可以实现ACDsee等看图软件的部分功能.它可以对图片进行移动,缩放,旋转,翻转,可以前后浏览一组图片.该图片查看器还支持移动设备, ...
- 帝国CMS7.2新增多图同时上传插件,上传多图效率更高
原来上传多图文件,需要挨个选择文件,然后再点批量上传,比较麻烦.所以帝国CMS7.2新增了多图上传插件:为采用FLASH方式实现同时选择多个图片一起上传,提高多图上传效率. 帝国CMS多图上传插件特性 ...
- flatpickr功能强大的日期时间选择器插件
flatpickr日期时间选择器支持移动手机,提供多种内置的主题效果,并且提供对中文的支持.它的特点还有: 使用SVG作为界面的图标. 兼容jQuery. 支持对各种日期格式的解析. 轻量级,高性能, ...
- 分享10款功能强大的HTML5/CSS3应用插件
1.纯CSS3美化Checkbox和Radiobox按钮 外观很时尚 利用CSS3我们可以打造非常具有个性化的用户表单,今天我们就利用CSS3美化Checkbox复选框和Radiobox单选框.CSS ...
- Barcode.js功能强大的条码生成jQuery插件
本文转载自http://www.uedsc.com/barcode-js.html Barcode.js是一个基于jQuery库的插件,用于绘制条形码或者二维码,能够生成基于DIV+CSS或者Canv ...
- 分享一个好用的功能强大的节点树jQuery插件
http://www.treejs.cn/
- SpringMVC使用MultipartFile文件上传,多文件上传,带参数上传
一.配置SpringMVC 二.单文件与多文件上传 三.多文件上传 四.带参数上传 一.配置SpringMVC 在spring.xml中配置: <!-- springmvc文件上传需要配置的节点 ...
- PHP 多图上传,图片批量上传插件,webuploader.js,百度文件上传插件
PHP 多图上传,图片批量上传插件,webuploader.js,百度文件上传插件(案例教程) WebUploader作用:http://fex.baidu.com/webuploader/gett ...
随机推荐
- ant使用备忘
ant是一个脚本构建工具,可能就是持续集成里面所需要的构建工具. 如果使用eclipse,里面会自带有ant工具,不需要再安装了,创建一个build.xml(或者其他的名字都可以),使用ant来运行就 ...
- 疯狂JAVA——第八章 java集合
集合类主要负责保存.盛装其他数据,因此集合类也被称为容器类. 数组元素既可以是基本类型的值,也可以是对象(实际上是保存的对象的引用): 集合里只能保存对象.
- $(this).form("validate") 始终返回false
onsubmit 提交前触发,返回 false 来阻止提交动作. validate 进行表单字段验证,当全部字段都有效时返回 true .该方法和 validatebox 插件一起使用. 解决:注释掉 ...
- Access to the path 'C:\inetpub\wwwroot\mysite\images\savehere' is denied.
访问路径被拒绝 我解决了这个设置: IIS>应用程序池> [您的站点]>高级设置...>标识>内置帐户> LocalSystem
- Ubuntu 16.04安装Git及GUI客户端
1.通过APT源安装Git命令行工具 这里不建议通过源码进行安装,增加复杂程度,且最新版本的Git在各个方面都会修复,不至于出现不能用的状态. sudo add-apt-repository ppa: ...
- C++,坑...
如果使用const全局变量,记得声明处的引用处都加extern. uint32_t等,t代表是typedef的,在stdint.h头文件里,C99后引入,记得先测试再用. accept函数的参数,记得 ...
- Gridview中 LinkButton删除以及自带删除
<asp:LinkButton ID="lbtnDel" OnClientClick="return confirm('删除新闻会连同其下评论一起删除,是否删除?' ...
- [leetcode]680. Valid Palindrome II有效回文II(可至多删一原字符)
Given a non-empty string s, you may delete at most one character. Judge whether you can make it a pa ...
- 20-最大k乘积问题
/* 最大k乘积问题 题目内容: 设I是一个n位十进制整数.如果将I划分为k段,则可得到k个整数. ...
- mysql经典案例分析
问题: create table A ( id varchar(64) primary key, ver int, ...)在id,ver上有联合索引,10000条数据为什么select id fro ...