Web Uploader -- 一个简单的以HTML5为主,FLASH为辅的现代文件上传组件

作者:赵金添 分类: 前端 发布于:2014-11-24 16:33 ė2836次浏览 60条评论
WebUploader是由Baidu WebFE(FEX)团队开发的一个简单的以HTML5为主,FLASH为辅的现代文件上传组件。在现代的浏览器里面能充分发挥HTML5的优势,同时又不摒弃主流IE浏览器,沿用原来的FLASH运行时,兼容IE6+,iOS 6+, android 4+。两套运行时,同样的调用方式,可供用户任意选用。
采用大文件分片并发上传,极大的提高了文件上传效率。

如何使用:http://fex.baidu.com/webuploader/getting-started.html
api文档:http://fex.baidu.com/webuploader/doc/index.html

简单实例:
html:
<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8" />
  <title>文件上传</title>
  <style>
    .webuploader-container {
      position: relative;
    }
    .webuploader-element-invisible {
      position: absolute !important;
      clip: rect(1px 1px 1px 1px); /* IE6, IE7 */
      clip: rect(1px,1px,1px,1px);
    }
    .webuploader-pick {
      position: relative;
      display: inline-block;
      cursor: pointer;
      background: #00b7ee;
      padding: 10px 15px;
      color: #fff;
      text-align: center;
      overflow: hidden;
    }
    .webuploader-pick-hover {
      background: #00a2d4;
    }
    .webuploader-pick-disable {
      opacity: 0.6;
      pointer-events:none;
    }
  </style>
</head>
<body>
<div id="file-list"></div>
<div id="picker">选择文件</div>
<button id="btn">开始上传</button>
<script src="//libs.cncdn.cn/jquery/2.1.1/jquery.min.js"></script>
<script type="text/javascript" src="/webuploader-0.1.5/webuploader.js"></script>
<script src="js/up.js"></script>
</body>
</html>

js:
// 文件上传
$(function() {
    var $list = $('#file-list'),
        $btn = $('#btn'),
        state = 'pending',
        uploader;

    uploader = WebUploader.create({
        // 不压缩image
        resize: false,

        // swf文件路径
        swf: '/webuploader-0.1.5/Uploader.swf',

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

        // 选择文件的按钮。可选。
        // 内部根据当前运行是创建,可能是input元素,也可能是flash.
        pick: '#picker'
    });

    // 当有文件添加进来的时候
    uploader.on( 'fileQueued', function( file ) {
        $list.append(
            '<div id="' + file.id + '">' +
            '  <h4>' + file.name + '</h4>' +
            '  <p class="state">等待上传...</p>' +
            '  <p class="progress">0%</p>' +
            '</div>'
        );
    });

    // 文件上传过程中创建进度条实时显示。
    uploader.on( 'uploadProgress', function( file, percentage ) {
        $('#' + file.id).find('.state').html('上传中').end().find('.progress').html(percentage * 100 + '%');
    });

    uploader.on( 'uploadSuccess', function( file ) {
        $( '#' + file.id ).find('p.state').text('已上传');
    });

    uploader.on( 'uploadError', function( file ) {
        $( '#' + file.id ).find('p.state').text('上传出错');
    });

    uploader.on( 'uploadComplete', function( file ) {
    });

    uploader.on( 'all', function( type ) {
        if ( type === 'startUpload' ) {
            state = 'uploading';
        } else if ( type === 'stopUpload' ) {
            state = 'paused';
        } else if ( type === 'uploadFinished' ) {
            state = 'done';
        }

        if ( state === 'uploading' ) {
            $btn.text('暂停上传');
        } else {
            $btn.text('开始上传');
        }
    });

    // 文件上传请求的参数表
    uploader.option('formData', {
        item: 'this is form data!'
    });

    $btn.on( 'click', function() {
        if ( state === 'uploading' ) {
            uploader.stop();
        } else {
            uploader.upload();
        }
    });
});

本文出自 赵金添的前端博客@福州软件外包公司,转载时请注明出处及相应链接。

0
分享本文至:

发表评论

电子邮件地址不会被公开。必填项已用*标注


Ɣ回顶部