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

简介: WebUploader是由Baidu WebFE(FEX)团队开发的一个以HTML5/FLASH构建的现代文件上传组件。

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中的代码,这里就不贴出来了,大家可以下载源码来学习。 
 
Web Uploader项目的官网地址:http://fex.baidu.com/webuploader/

这里可以看演示效果 功能强大的文件上传插件带上传进度
相关文章
|
存储 缓存 测试技术
ZYNQ-AXI Interconnect IP介绍
ZYNQ-AXI Interconnect IP介绍
3645 0
ZYNQ-AXI Interconnect IP介绍
|
10月前
|
监控 数据挖掘 API
利用拼多多 API 接口,实现拼多多店铺物流时效优化
在电商竞争激烈的今天,物流时效直接影响拼多多店铺的客户满意度与复购率。本文介绍如何通过拼多多开放平台的 API 接口,自动化获取订单与物流数据,分析时效瓶颈并制定优化策略。内容涵盖 API 基本功能、物流数据分析、智能优化方法及 Python 实现示例,帮助商家提升配送效率,降低退货率,增强用户体验与店铺竞争力。
1265 0
|
Web App开发 前端开发 安全
2024年新一代WebOffice内嵌网页组件,Web网页在线编辑Word/Excel/PPT
WebOffice控件面临兼容性、用户体验和维护难题。随着浏览器更新,依赖插件的技术不再适用,如Chrome不再支持NPAPI和PPAPI。产品普遍不支持多版本Office并存,定制能力弱,升级复杂。猿大师办公助手提供了解决方案,它兼容多种浏览器,包括最新版和国产浏览器,不依赖插件,支持文档对比,具有丰富的功能和接口,兼容多种Office版本,允许源码级定制,提供终身技术支持,并实现静默在线升级。适用于多种行业和操作系统。
1441 122
|
监控 Java 物联网
Java串口通信技术探究1:深入理解RXTX库
Java串口通信技术探究1:深入理解RXTX库
808 2
|
存储 监控 Docker
如何限制docker使用的cpu,内存,存储
如何限制docker使用的cpu,内存,存储
|
前端开发 JavaScript API
使用 Prism.js 对代码进行语法高亮
通常我们在开发博客网站或者技术社区(类似掘金)这类网站的时候,就会有需求“对代码进行语法高亮”,本文主要记录笔者在开发的时候遇到的问题以及解决方案。
1938 0
|
消息中间件 数据库 开发者
深入理解Python中的异步编程:从基础到高级应用
在当今高并发、低延迟的应用需求下,异步编程已成为提升性能的关键技术之一。本文不仅剖析了Python中异步编程的基本原理,如事件循环、协程与async/await语法,还深入探讨了异步编程的高级应用场景,如Web框架(如FastAPI)中的异步IO操作、异步数据库交互及构建高效的任务处理系统。通过实战案例,引导读者从理论到实践,全面掌握Python异步编程的精髓,让代码飞起来,轻松应对大规模并发挑战。
|
JavaScript
js 一键复制到剪贴板(原生js实现)
js 一键复制到剪贴板(原生js实现)
233 0
从基础到高级,带你深入了解和使用curl命令(一)
`curl`命令是网络通信中的强大工具,用于与HTTP、HTTPS、FTP等协议交互,支持多种操作。基本语法是`curl [options] [URL]`,包含如`-A`设置用户代理,`-b`处理cookie,`-o`保存输出到文件,`-x`指定代理等选项。示例包括请求网址、保存网页、使用代理及模仿浏览器访问。本文为`curl`基础用法介绍,后续将探讨更多高级功能。