webuploader基本使用

2019-04-16  本文已影响0人  AsaGuo

index.html

<!DOCTYPE html>
<head>
    <meta charset="utf-8">
    <title>文件上传</title>

    <!--引入CSS-->
    <link rel="stylesheet" type="text/css" href="../../js/lib/webuploader/webuploader.css">

    <!--引入JS-->
    <script src="../../assets/plugins/jquery-1.11.1.min.js"></script>
    <script type="text/javascript" src="../../js/lib/webuploader/webuploader.js"></script>

    <!--SWF在初始化的时候指定,在后面将展示-->
</head>
<body>
<div id="uploader" class="wu-example">
    <!--用来存放文件信息-->
    <div id="thelist" class="uploader-list">

    </div>

    <div class="btns" class="webuploader-container">
        <div id="piker">选择文件</div>
        <input type="file" name="file" class="webuploader-element-invisible" multiple="multiple">

        <label  style="opacity: 0;
                width: 100%;
                height: 100%;
                display: block;
                cursor: pointer;
                background: rgb(255, 255, 255);"></label>
        <button id="startBtn" class="btn btn-default">开始上传</button>
        <button id="refreshBtn" class="btn btn-default" >重置</button>
    </div>
</div>
</body>
</html>

<script>
    window.onload = () => {
        let BASE_URL = "../../js/lib/webuploader/";

        console.log('WebUploader.create BEGIN *******************************');
        var uploader = WebUploader.create({
            swf: BASE_URL + 'Uploader.swf',// swf文件路径
            server: 'http://localhost:4001/backend/upload/image',// 文件接收服务端

            // 选择文件的按钮,可选。
            // 内部根据当前运行时创建,可能是input元素,也可能是flash.
            pick: '#piker',
            resize: false,// 不压缩image,默认如果是jpeg,文件上传前会压缩一把再上传!
            // auto:true,
            thumb:{
                width: 50,
                height: 50,
                quality: 70,// 图片质量,只有type为`image/jpeg`的时候才有效。

                // 是否允许放大,如果想要生成小图的时候不失真,此选项应该设置为false.
                allowMagnify: false ,
                crop: true,// 是否允许裁剪。
                type: ''// 为空的话则保留原有图片格式。否则强制转换成指定的类型。
            }
        });

        // 当有文件被添加进队列的时候
        uploader.on('fileQueued', file => {
            $list = $('#thelist');
            $item = $(file.id);

            // 缩略图
            uploader.makeThumb( file, function( error, ret ) {
                let info = '<div id="' + file.id + '" class="item" onclick="click()">' +
                    '<img alt="" src="' + ret + '" />' +
                    '<h5 class="info">' + file.name + '</h5>' +
                    '<p class="state">等待上传...</p>' +
                    '</div>';

                if ( error ) {
                    $list.text('预览错误');
                } else {
                    $list.append(info);

                    // 删除按钮
                    $item.on('click', function() {
                        uploader.removeFile(file,true);
                    })
                }
            });
        });

        // 开始上传
        $("#startBtn").on('click', function () {
            uploader.upload();
        });

        // 重置
        $("#refreshBtn").on('click', function () {
            let files = uploader.getFiles();
            files.forEach(file => {
                uploader.removeFile(file.id);// 清空文件队列
                $("#" + file.id).remove();// 删除div
            });

            uploader.reset();//清空队列
        });

        // 文件上传过程中创建进度条实时显示。
        uploader.on('uploadProgress', (file, percentage) => {
            var $li = $('#' + file.id),
                $percent = $li.find('.progress .progress-bar');

            // 避免重复创建
            if (!$percent.length) {
                $percent = $('<div class="progress progress-striped active">' +
                    '<div class="progress-bar" role="progressbar" style="width: 0%">' +
                    '</div>' +
                    '</div>').appendTo($li).find('.progress-bar');
            }
            $li.find('p.state').text('上传中');
            $percent.css('width', percentage * 100 + '%');
        });

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

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

        uploader.on('uploadComplete', file => {
            $('#' + file.id).find('.progress').fadeOut();
        });
    }
</script>
上一篇 下一篇

猜你喜欢

热点阅读