最新赞助活动温馨提示:自愿赞助服务器费用,学生和没有工作的整站资源免费下载!
头像

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

来源:http://www.erdangjiade.com/ 沐浴春风 2016-07-23 13:30浏览(2663)

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

0、请不要问“在不在”之类的问题,有问题直接问!1、学生或暂时没有工作的童鞋,整站资源免费下载!2、¥9.9充值终身VIP会员,加我微信,826096331 拉你进VIP群学习!3、程序员加油,技术改变世界。在线 充值

功能强大的文件上传插件带上传进度-WebUploader
分类:表单代码 > 图片上传 难易:初级
查看演示

加我微信,拉你进VIP群学习:

下载资源 下载积分: 30 积分

我们首先将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/
声明:本文为原创文章,如需转载,请注明来源erdangjiade.com并保留原文链接:https://www.erdangjiade.com/js/901.html
评论5
头像

友情提示:垃圾评论一律封号 加我微信:826096331拉你进VIP群学习群

  • 头像 4楼
    09-15 09:41
    希望没问题
    我还是去js官网吧
  • 头像 3楼
    01-16 14:56
    pudilu
    来一发!
  • 头像 板凳
    05-17 14:28
    cz521000
    确实精采,多实用性!
  • 头像 椅子
    03-20 00:09
    ssoo88
    不错!!!!!!!!
  • 头像 沙发
    03-10 17:23
    13717866946@163.com
    不错!!!!!!!!!!!!!!!!!!!!!!!!
1 2