功能强大的文件上传插件带上传进度-WebUploader

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

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

选择图片

 
  1. 首先js创建Web Uploader实例:

  2.  
  3. var uploader = WebUploader.create({

  4. auto: true, // 选完文件后,是否自动上传

  5. swf: 'js/Uploader.swf', // swf文件路径

  6. server: 'upload.php', // 文件接收服务端

  7. pick: '#imgPicker', // 选择文件的按钮。可选

  8. // 只允许选择图片文件。

  9. accept: {

  10. title: 'Images',

  11. extensions: 'gif,jpg,jpeg,bmp,png',

  12. mimeTypes: 'image/*'

  13. }

  14. });

  15.  
  16.  
  17. uploader.on( 'fileQueued', function( file ) {

  18. var $list = $("#fileList"),

  19. $li = $(

  20. '<div id="' + file.id + '" class="file-item thumbnail">' +

  21. '<img>' +

  22. '<div class="info">' + file.name + '</div>' +

  23. '</div>'

  24. ),

  25. $img = $li.find('img');

  26.  
  27.  
  28. // $list为容器jQuery实例

  29. $list.append( $li );

  30.  
  31. // 创建缩略图

  32. uploader.makeThumb( file, function( error, src ) {

  33. if ( error ) {

  34. $img.replaceWith('<span>不能预览</span>');

  35. return;

  36. }

  37.  
  38. $img.attr( 'src', src );

  39. }, 100, 100 ); //100x100为缩略图尺寸

  40. });

  41. // 文件上传过程中创建进度条实时显示。

  42. uploader.on( 'uploadProgress', function( file, percentage ) {

  43. var $li = $( '#'+file.id ),

  44. $percent = $li.find('.progress span');

  45.  
  46. // 避免重复创建

  47. if ( !$percent.length ) {

  48. $percent = $('<p class="progress"><span></span></p>')

  49. .appendTo( $li )

  50. .find('span');

  51. }

  52.  
  53. $percent.css( 'width', percentage * 100 + '%' );

  54. });

  55.  
  56. // 文件上传成功,给item添加成功class, 用样式标记上传成功。

  57. uploader.on( 'uploadSuccess', function( file, res ) {

  58. console.log(res.filePath);//这里可以得到上传后的文件路径

  59. $( '#'+file.id ).addClass('upload-state-done');

  60. });

  61.  
  62. // 文件上传失败,显示上传出错。

  63. uploader.on( 'uploadError', function( file ) {

  64. var $li = $( '#'+file.id ),

  65. $error = $li.find('div.error');

  66.  
  67. // 避免重复创建

  68. if ( !$error.length ) {

  69. $error = $('<div class="error"></div>').appendTo( $li );

  70. }

  71.  
  72. $error.text('上传失败');

  73. });

  74.  
  75. // 完成上传完了,成功或者失败,先删除进度条。

  76. uploader.on( 'uploadComplete', function( file ) {

  77. $( '#'+file.id ).find('.progress').remove();

  78. });

  79. .prev{left: 20px}

  80. .next{right: 20px}

  81. PHP处理文件上传

  82.  
  83. upload.php接收上传数据,将上传的文件保存到服务器相关目录,并将上传结果告知前端上传组件。

  84.  
  85. 这里值得一提的是,如果设置了大文件分片上传,PHP将每次上传的小文件片临时保存,等最后文件片全部接收完毕后再将这些临时文件片组合,成为一个完整的大文件。

  86.  
  87. webuploader的分片上传是把文件分成若干份,然后向你定义的文件接收端post数据,如果上传的文件大于分片的尺寸,就会进行分片,然后会在post的数据中添加两个form元素chunk和chunks,前者标示当前分片在上传分片中的顺序(从0开始),后者代表总分片数。

  88.  
  89. 关于upload.php中的代码,这里就不贴出来了,大家可以下载源码来学习。

  90.  
  91. Web Uploader项目的官网地址:https://0x9.me/q2aln


这里可以看演示效果功能强大的文件上传插件带上传进度

猜你喜欢

转载自blog.csdn.net/germy2/article/details/87914608
今日推荐