WebUploader是由Baidu WebFE(FEX)团队开发的一个以HTML5/FLASH构建的现代文件上传组件。在现代的浏览器里面能充分发挥HTML5的优势,同时又不摒弃主流IE浏览器,沿用老的FLASH运行时,兼容PC和移动端。它最大的特点是采用大文件分片并发上传,极大的提高了文件上传效率。touchend略要处理下。功能强大的文件上传插件带上传进度 ,有兴趣请直接下载源码拿去用。

我们首先将css和相关js文件加载。然后我们需要准备一个按钮#imgPicker,和一个用来存放添加的文件信息列表的容器#fileList,在body中加入如下代码:

选择图片

  1. 首先js创建Web Uploader实例:
  2. var uploader = WebUploader.create({
  3. auto: true, // 选完文件后,是否自动上传
  4. swf: 'js/Uploader.swf', // swf文件路径
  5. server: 'upload.php', // 文件接收服务端
  6. pick: '#imgPicker', // 选择文件的按钮。可选
  7. // 只允许选择图片文件。
  8. accept: {
  9. title: 'Images',
  10. extensions: 'gif,jpg,jpeg,bmp,png',
  11. mimeTypes: 'image/*'
  12. }
  13. });
  14. uploader.on( 'fileQueued', function( file ) {
  15. var $list = $("#fileList"),
  16. $li = $(
  17. '<div id="' + file.id + '" class="file-item thumbnail">' +
  18. '<img>' +
  19. '<div class="info">' + file.name + '</div>' +
  20. '</div>'
  21. ),
  22. $img = $li.find('img');
  23. // $list为容器jQuery实例
  24. $list.append( $li );
  25. // 创建缩略图
  26. uploader.makeThumb( file, function( error, src ) {
  27. if ( error ) {
  28. $img.replaceWith('<span>不能预览</span>');
  29. return;
  30. }
  31. $img.attr( 'src', src );
  32. }, 100, 100 ); //100x100为缩略图尺寸
  33. });
  34. // 文件上传过程中创建进度条实时显示。
  35. uploader.on( 'uploadProgress', function( file, percentage ) {
  36. var $li = $( '#'+file.id ),
  37. $percent = $li.find('.progress span');
  38. // 避免重复创建
  39. if ( !$percent.length ) {
  40. $percent = $('<p class="progress"><span></span></p>')
  41. .appendTo( $li )
  42. .find('span');
  43. }
  44. $percent.css( 'width', percentage * 100 + '%' );
  45. });
  46. // 文件上传成功,给item添加成功class, 用样式标记上传成功。
  47. uploader.on( 'uploadSuccess', function( file, res ) {
  48. console.log(res.filePath);//这里可以得到上传后的文件路径
  49. $( '#'+file.id ).addClass('upload-state-done');
  50. });
  51. // 文件上传失败,显示上传出错。
  52. uploader.on( 'uploadError', function( file ) {
  53. var $li = $( '#'+file.id ),
  54. $error = $li.find('div.error');
  55. // 避免重复创建
  56. if ( !$error.length ) {
  57. $error = $('<div class="error"></div>').appendTo( $li );
  58. }
  59. $error.text('上传失败');
  60. });
  61. // 完成上传完了,成功或者失败,先删除进度条。
  62. uploader.on( 'uploadComplete', function( file ) {
  63. $( '#'+file.id ).find('.progress').remove();
  64. });
  65. .prev{left: 20px}
  66. .next{right: 20px}
  67. PHP处理文件上传
  68. upload.php接收上传数据,将上传的文件保存到服务器相关目录,并将上传结果告知前端上传组件。
  69. 这里值得一提的是,如果设置了大文件分片上传,PHP将每次上传的小文件片临时保存,等最后文件片全部接收完毕后再将这些临时文件片组合,成为一个完整的大文件。
  70. webuploader的分片上传是把文件分成若干份,然后向你定义的文件接收端post数据,如果上传的文件大于分片的尺寸,就会进行分片,然后会在post的数据中添加两个form元素chunk和chunks,前者标示当前分片在上传分片中的顺序(从0开始),后者代表总分片数。
  71. 关于upload.php中的代码,这里就不贴出来了,大家可以下载源码来学习。
  72. http://c7.gg/fw4sn

功能强大的文件上传插件带上传进度-WebUploader的更多相关文章

  1. 插件介绍 :cropper是一款使用简单且功能强大的图片剪裁jQuery插件。

    简要教程 cropper是一款使用简单且功能强大的图片剪裁jQuery插件.该图片剪裁插件支持图片放大缩小,支持鼠标滚轮操作,支持图片旋转,支持触摸屏设备,支持canvas,并且支持跨浏览器使用. c ...

  2. jQuery功能强大的图片查看器插件

    简要教程 viewer是一款功能强大的图片查看器jQuery插件.它可以实现ACDsee等看图软件的部分功能.它可以对图片进行移动,缩放,旋转,翻转,可以前后浏览一组图片.该图片查看器还支持移动设备, ...

  3. 帝国CMS7.2新增多图同时上传插件,上传多图效率更高

    原来上传多图文件,需要挨个选择文件,然后再点批量上传,比较麻烦.所以帝国CMS7.2新增了多图上传插件:为采用FLASH方式实现同时选择多个图片一起上传,提高多图上传效率. 帝国CMS多图上传插件特性 ...

  4. flatpickr功能强大的日期时间选择器插件

    flatpickr日期时间选择器支持移动手机,提供多种内置的主题效果,并且提供对中文的支持.它的特点还有: 使用SVG作为界面的图标. 兼容jQuery. 支持对各种日期格式的解析. 轻量级,高性能, ...

  5. 分享10款功能强大的HTML5/CSS3应用插件

    1.纯CSS3美化Checkbox和Radiobox按钮 外观很时尚 利用CSS3我们可以打造非常具有个性化的用户表单,今天我们就利用CSS3美化Checkbox复选框和Radiobox单选框.CSS ...

  6. Barcode.js功能强大的条码生成jQuery插件

    本文转载自http://www.uedsc.com/barcode-js.html Barcode.js是一个基于jQuery库的插件,用于绘制条形码或者二维码,能够生成基于DIV+CSS或者Canv ...

  7. 分享一个好用的功能强大的节点树jQuery插件

    http://www.treejs.cn/

  8. SpringMVC使用MultipartFile文件上传,多文件上传,带参数上传

    一.配置SpringMVC 二.单文件与多文件上传 三.多文件上传 四.带参数上传 一.配置SpringMVC 在spring.xml中配置: <!-- springmvc文件上传需要配置的节点 ...

  9. PHP 多图上传,图片批量上传插件,webuploader.js,百度文件上传插件

    PHP  多图上传,图片批量上传插件,webuploader.js,百度文件上传插件(案例教程) WebUploader作用:http://fex.baidu.com/webuploader/gett ...

随机推荐

  1. jquery 阻止冒泡事件和阻止默认事件

    jQuery 冒泡和默认事件: <!DOCTYPE html> <html lang="en"> <head> <meta charset ...

  2. HIBERNATE知识复习记录3-关联关系

    先上一张图,关于几种关系映射: 抄一段解释: 基本映射是对一个实体进行映射,关联映射就是处理多个实体之间的关系,将关联关系映射到数据库中,所谓的关联关系在对象模型中有一个或多个引用.关联关系分为上述七 ...

  3. 一个取消事件的简单js例子(事件冒泡与取消默认行为)

    先上代码: <div id='outer' onclick='alert("我是outer")'> <div id="middle" oncl ...

  4. 在Linux Bash通过上下键快速查找历史命令

    在centos 7中 ~/.bashrc 或者Mac中的 ~/.bash_profile 中添加,然后source一下以下内容: if [[ $- == *i* ]] then bind '" ...

  5. linux 初始设置

    vim .bashrc 添加下行 自用: export PS1="Host:\[\033[1;35m\]\H \[\033[0m\]User:\[\033[1;33m\]\u \[\033[ ...

  6. Hibernate DetachedCriteria实现

     前段时间在做模糊查询,并利用数据库分页,DAO用hibernate实现,刚开始的时候 根据业务层的数据,拼hql语句进行查询,且不说要进行一些if判断,单从结构上来说, 底层的数据访问层依赖于业务层 ...

  7. c#数和二叉树

    树(Tree)是 n(n≥0)个相同类型的数据元素的有限集合.树中的数据元素叫结点(Node).n=0 的树称为空树(Empty Tree):对于 n>0 的任意非空树 T 有: (1)有且仅有 ...

  8. Wilcoxon Signed Rank Test

    1.Wilcoxon Signed Rank Test Wilcoxon有符号秩检验(也称为Wilcoxon有符号秩和检验)是一种非参数检验.当统计数据中使用“非参数”一词时,并不意味着您对总体一无所 ...

  9. Maven常用命令及Eclipse应用

    一般来说,github上大多的java项目都是使用maven,ant等进行构建的.由于之前没有使用过maven,因此这几天对maven进行了简单的学习.古话说:“温故而知新”,一些命令长时间不使用都会 ...

  10. asp.net回发页面被刷新后悔重新执行回发事件的解决方法

    做项目,进行数据修改操作后,重新加载数据,本来是没问题的.但是在这个时候刷新下页面,发现修改操作又重新执行了一次,并弹出“修改成功”的提示框. 百度了下,找到以下解决方法,解决了问题: Page.Cl ...