zoukankan      html  css  js  c++  java
  • webuploader 教程

    1、引入js和css

    <!-- Web Uploader -->
    <link rel="stylesheet" type="text/css"href="css/plugins/webuploader/webuploader.css">
    <script src="js/plugins/webuploader/webuploader.min.js"></script>

    2、自定义的格式

    <div class="page-container">
        <div id="uploader" class="wu-example">
            <div class="queueList">
                <div id="dndArea" class="placeholder">
                    <div id="filePicker"></div>
                    <p>或将照片拖到这里,单次最多可选300张</p>
                </div>
            </div>
            <div class="statusBar" style="display:none;">
                <div class="progress">
                    <span class="text">0%</span>
                    <span class="percentage"></span>
                </div>
                <div class="info"></div>
                <div class="btns">
                    <div id="filePicker2"></div>
                    <div class="uploadBtn">开始上传</div>
                </div>
            </div>
        </div>
    </div>

    3、css样式(webuploader-demo.css)

    #container {
        color: #838383;
        font-size: 12px;
    }
    
    #uploader .queueList {
        /*margin: 20px;*/
        border: 3px dashed #e6e6e6;
    }
    #uploader .queueList.filled {
        padding: 17px;
        margin: 0;
        border: 3px dashed transparent;
    }
    #uploader .queueList.webuploader-dnd-over {
        border: 3px dashed #999999;
    }
    
    #uploader p {margin: 0;}
    
    .element-invisible {
        position: absolute !important;
        clip: rect(1px 1px 1px 1px); /* IE6, IE7 */
        clip: rect(1px,1px,1px,1px);
    }
    
    #uploader .placeholder {
        min-height: 350px;
        padding-top: 178px;
        text-align: center;
        background: url(../../img/webuploader.png) center 93px no-repeat;
        color: #cccccc;
        font-size: 18px;
        position: relative;
    }
    
    #uploader .placeholder .webuploader-pick {
        font-size: 18px;
        background: #00b7ee;
        border-radius: 3px;
        line-height: 44px;
        padding: 0 30px;
        * 120px;
        color: #fff;
        display: inline-block;
        margin: 0 auto 20px auto;
        cursor: pointer;
        box-shadow: 0 1px 1px rgba(0, 0, 0, 0.1);
    }
    
    #uploader .placeholder .webuploader-pick-hover {
        background: #00a2d4;
    }
    
    #uploader .placeholder .flashTip {
        color: #666666;
        font-size: 12px;
        position: absolute;
         100%;
        text-align: center;
        bottom: 20px;
    }
    #uploader .placeholder .flashTip a {
        color: #0785d1;
        text-decoration: none;
    }
    #uploader .placeholder .flashTip a:hover {
        text-decoration: underline;
    }
    
    #uploader .filelist {
        list-style: none;
        margin: 0;
        padding: 0;
    }
    
    #uploader .filelist:after {
        content: '';
        display: block;
         0;
        height: 0;
        overflow: hidden;
        clear: both;
    }
    
    #uploader .filelist li {
         110px;
        height: 110px;
        background: url(../../img/bg.png) no-repeat;
        text-align: center;
        margin: 0 8px 20px 0;
        position: relative;
        display: inline;
        float: left;
        overflow: hidden;
        font-size: 12px;
    }
    
    #uploader .filelist li p.log {
        position: relative;
        top: -45px;
    }
    
    #uploader .filelist li p.title {
        position: absolute;
        top: 0;
        left: 0;
         100%;
        overflow: hidden;
        white-space: nowrap;
        text-overflow : ellipsis;
        top: 5px;
        text-indent: 5px;
        text-align: left;
    }
    
    #uploader .filelist li p.progress {
        position: absolute;
         100%;
        bottom: 0;
        left: 0;
        height: 8px;
        overflow: hidden;
        z-index: 50;
        margin: 0;
        border-radius: 0;
        background: none;
        -webkit-box-shadow: 0 0 0;
    }
    #uploader .filelist li p.progress span {
        display: none;
        overflow: hidden;
         0;
        height: 100%;
        background: #1483d8 url(../../img/progress.png) repeat-x;
    
        -webit-transition: width 200ms linear;
        -moz-transition: width 200ms linear;
        -o-transition: width 200ms linear;
        -ms-transition: width 200ms linear;
        transition: width 200ms linear;
    
        -webkit-animation: progressmove 2s linear infinite;
        -moz-animation: progressmove 2s linear infinite;
        -o-animation: progressmove 2s linear infinite;
        -ms-animation: progressmove 2s linear infinite;
        animation: progressmove 2s linear infinite;
    
        -webkit-transform: translateZ(0);
    }
    
    @-webkit-keyframes progressmove {
        0% {
           background-position: 0 0;
        }
        100% {
           background-position: 17px 0;
        }
    }
    @-moz-keyframes progressmove {
        0% {
           background-position: 0 0;
        }
        100% {
           background-position: 17px 0;
        }
    }
    @keyframes progressmove {
        0% {
           background-position: 0 0;
        }
        100% {
           background-position: 17px 0;
        }
    }
    
    #uploader .filelist li p.imgWrap {
        position: relative;
        z-index: 2;
        line-height: 110px;
        vertical-align: middle;
        overflow: hidden;
         110px;
        height: 110px;
    
        -webkit-transform-origin: 50% 50%;
        -moz-transform-origin: 50% 50%;
        -o-transform-origin: 50% 50%;
        -ms-transform-origin: 50% 50%;
        transform-origin: 50% 50%;
    
        -webit-transition: 200ms ease-out;
        -moz-transition: 200ms ease-out;
        -o-transition: 200ms ease-out;
        -ms-transition: 200ms ease-out;
        transition: 200ms ease-out;
    }
    
    #uploader .filelist li img {
         100%;
    }
    
    #uploader .filelist li p.error {
        background: #f43838;
        color: #fff;
        position: absolute;
        bottom: 0;
        left: 0;
        height: 28px;
        line-height: 28px;
         100%;
        z-index: 100;
    }
    
    #uploader .filelist li .success {
        display: block;
        position: absolute;
        left: 0;
        bottom: 0;
        height: 40px;
         100%;
        z-index: 200;
        background: url(../../img/success.png) no-repeat right bottom;
    }
    
    #uploader .filelist div.file-panel {
        position: absolute;
        height: 0;
        filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0,startColorstr='#80000000', endColorstr='#80000000')0;
        background: rgba( 0, 0, 0, 0.5 );
         100%;
        top: 0;
        left: 0;
        overflow: hidden;
        z-index: 300;
    }
    
    #uploader .filelist div.file-panel span {
         24px;
        height: 24px;
        display: inline;
        float: right;
        text-indent: -9999px;
        overflow: hidden;
        background: url(../../img/icons.png) no-repeat;
        margin: 5px 1px 1px;
        cursor: pointer;
    }
    
    #uploader .filelist div.file-panel span.rotateLeft {
        background-position: 0 -24px;
    }
    #uploader .filelist div.file-panel span.rotateLeft:hover {
        background-position: 0 0;
    }
    
    #uploader .filelist div.file-panel span.rotateRight {
        background-position: -24px -24px;
    }
    #uploader .filelist div.file-panel span.rotateRight:hover {
        background-position: -24px 0;
    }
    
    #uploader .filelist div.file-panel span.cancel {
        background-position: -48px -24px;
    }
    #uploader .filelist div.file-panel span.cancel:hover {
        background-position: -48px 0;
    }
    
    #uploader .statusBar {
        height: 63px;
        border-top: 1px solid #dadada;
        padding: 0 20px;
        line-height: 63px;
        vertical-align: middle;
        position: relative;
    }
    
    #uploader .statusBar .progress {
        border: 1px solid #1483d8;
         198px;
        background: #fff;
        height: 18px;
        position: relative;
        display: inline-block;
        text-align: center;
        line-height: 20px;
        color: #6dbfff;
        position: relative;
        margin: 0 10px 0 0;
    }
    #uploader .statusBar .progress span.percentage {
         0;
        height: 100%;
        left: 0;
        top: 0;
        background: #1483d8;
        position: absolute;
    }
    #uploader .statusBar .progress span.text {
        position: relative;
        z-index: 10;
    }
    
    #uploader .statusBar .info {
        display: inline-block;
        font-size: 14px;
        color: #666666;
    }
    
    #uploader .statusBar .btns {
        position: absolute;
        top: 10px;
        right: 20px;
        line-height: 40px;
    }
    
    #filePicker2 {
        display: inline-block;
        float: left;
    }
    
    #uploader .statusBar .btns .webuploader-pick,
    #uploader .statusBar .btns .uploadBtn,
    #uploader .statusBar .btns .uploadBtn.state-uploading,
    #uploader .statusBar .btns .uploadBtn.state-paused {
        background: #ffffff;
        border: 1px solid #cfcfcf;
        color: #565656;
        padding: 0 18px;
        display: inline-block;
        border-radius: 3px;
        margin-left: 10px;
        cursor: pointer;
        font-size: 14px;
        float: left;
    }
    #uploader .statusBar .btns .webuploader-pick-hover,
    #uploader .statusBar .btns .uploadBtn:hover,
    #uploader .statusBar .btns .uploadBtn.state-uploading:hover,
    #uploader .statusBar .btns .uploadBtn.state-paused:hover {
        background: #f0f0f0;
    }
    
    #uploader .statusBar .btns .uploadBtn {
        background: #00b7ee;
        color: #fff;
        border-color: transparent;
    }
    #uploader .statusBar .btns .uploadBtn:hover {
        background: #00a2d4;
    }
    
    #uploader .statusBar .btns .uploadBtn.disabled {
        pointer-events: none;
        opacity: 0.6;
    }

    4、初始化webuploader

    jQuery(function() {
        var $ = jQuery,    // just in case. Make sure it's not an other libaray.
    
            $wrap = $('#uploader'),
    
            // 图片容器
            $queue = $('<ul class="filelist"></ul>')
                .appendTo( $wrap.find('.queueList') ),
    
            // 状态栏,包括进度和控制按钮
            $statusBar = $wrap.find('.statusBar'),
    
            // 文件总体选择信息。
            $info = $statusBar.find('.info'),
    
            // 上传按钮
            $upload = $wrap.find('.uploadBtn'),
    
            // 没选择文件之前的内容。
            $placeHolder = $wrap.find('.placeholder'),
    
            // 总体进度条
            $progress = $statusBar.find('.progress').hide(),
    
            // 添加的文件数量
            fileCount = 0,
    
            // 添加的文件总大小
            fileSize = 0,
    
            // 优化retina, 在retina下这个值是2
            ratio = window.devicePixelRatio || 1,
    
            // 缩略图大小
            thumbnailWidth = 110 * ratio,
            thumbnailHeight = 110 * ratio,
    
            // 可能有pedding, ready, uploading, confirm, done.
            state = 'pedding',
    
            // 所有文件的进度信息,key为file id
            percentages = {},
    
            supportTransition = (function(){
                var s = document.createElement('p').style,
                    r = 'transition' in s ||
                          'WebkitTransition' in s ||
                          'MozTransition' in s ||
                          'msTransition' in s ||
                          'OTransition' in s;
                s = null;
                return r;
            })(),
    
            // WebUploader实例
            uploader;
    
        if ( !WebUploader.Uploader.support() ) {
            alert( 'Web Uploader 不支持您的浏览器!如果你使用的是IE浏览器,请尝试升级 flash 播放器');
            throw new Error( 'WebUploader does not support the browser you are using.' );
        }
    
        // 实例化
        uploader = WebUploader.create({
            pick: {
                id: '#filePicker',
                label: '点击选择图片'
            },
            dnd: '#uploader .queueList',
            paste: document.body,
    
            accept: {
                title: 'Images',
                extensions: 'gif,jpg,jpeg,bmp,png',
                mimeTypes: 'image/gif,image/jpg,image/jpeg,image/bmp,image/png,'
            },
    
            // swf文件路径
            swf: 'js/plugins/webuploader/Uploader.swf',
            disableGlobalDnd: true,
            
            //分页上传
            chunked: true,
            //服务器地址
            server: 'http://127.0.0.1:8080/api/json/file/upload/batch',
         //上传文件名 fileVal:'files'
    , fileNumLimit: 300, fileSizeLimit: 200 * 1024 * 1024, // 200 M fileSingleSizeLimit: 50 * 1024 * 1024 // 50 M }); // 添加“添加文件”的按钮, uploader.addButton({ id: '#filePicker2', label: '继续添加' }); // 当有文件添加进来时执行,负责view的创建 function addFile( file ) { var $li = $( '<li id="' + file.id + '">' + '<p class="title">' + file.name + '</p>' + '<p class="imgWrap"></p>'+ '<p class="progress"><span></span></p>' + '</li>' ), $btns = $('<div class="file-panel">' + '<span class="cancel">删除</span>' + '<span class="rotateRight">向右旋转</span>' + '<span class="rotateLeft">向左旋转</span></div>').appendTo( $li ), $prgress = $li.find('p.progress span'), $wrap = $li.find( 'p.imgWrap' ), $info = $('<p class="error"></p>'), showError = function( code ) { switch( code ) { case 'exceed_size': text = '文件大小超出'; break; case 'interrupt': text = '上传暂停'; break; default: text = '上传失败,请重试'; break; } $info.text( text ).appendTo( $li ); }; if ( file.getStatus() === 'invalid' ) { showError( file.statusText ); } else { // @todo lazyload $wrap.text( '预览中' ); uploader.makeThumb( file, function( error, src ) { if ( error ) { $wrap.text( '不能预览' ); return; } var img = $('<img src="'+src+'">'); $wrap.empty().append( img ); }, thumbnailWidth, thumbnailHeight ); percentages[ file.id ] = [ file.size, 0 ]; file.rotation = 0; } file.on('statuschange', function( cur, prev ) { if ( prev === 'progress' ) { $prgress.hide().width(0); } else if ( prev === 'queued' ) { $li.off( 'mouseenter mouseleave' ); $btns.remove(); } // 成功 if ( cur === 'error' || cur === 'invalid' ) { console.log( file.statusText ); showError( file.statusText ); percentages[ file.id ][ 1 ] = 1; } else if ( cur === 'interrupt' ) { showError( 'interrupt' ); } else if ( cur === 'queued' ) { percentages[ file.id ][ 1 ] = 0; } else if ( cur === 'progress' ) { $info.remove(); $prgress.css('display', 'block'); } else if ( cur === 'complete' ) { $li.append( '<span class="success"></span>' ); } $li.removeClass( 'state-' + prev ).addClass( 'state-' + cur ); }); $li.on( 'mouseenter', function() { $btns.stop().animate({height: 30}); }); $li.on( 'mouseleave', function() { $btns.stop().animate({height: 0}); }); $btns.on( 'click', 'span', function() { var index = $(this).index(), deg; switch ( index ) { case 0: uploader.removeFile( file ); return; case 1: file.rotation += 90; break; case 2: file.rotation -= 90; break; } if ( supportTransition ) { deg = 'rotate(' + file.rotation + 'deg)'; $wrap.css({ '-webkit-transform': deg, '-mos-transform': deg, '-o-transform': deg, 'transform': deg }); } else { $wrap.css( 'filter', 'progid:DXImageTransform.Microsoft.BasicImage(rotation='+ (~~((file.rotation/90)%4 + 4)%4) +')'); // use jquery animate to rotation // $({ // rotation: rotation // }).animate({ // rotation: file.rotation // }, { // easing: 'linear', // step: function( now ) { // now = now * Math.PI / 180; // var cos = Math.cos( now ), // sin = Math.sin( now ); // $wrap.css( 'filter', "progid:DXImageTransform.Microsoft.Matrix(M11=" + cos + ",M12=" + (-sin) + ",M21=" + sin + ",M22=" + cos + ",SizingMethod='auto expand')"); // } // }); } }); $li.appendTo( $queue ); } // 负责view的销毁 function removeFile( file ) { var $li = $('#'+file.id); delete percentages[ file.id ]; updateTotalProgress(); $li.off().find('.file-panel').off().end().remove(); } function updateTotalProgress() { var loaded = 0, total = 0, spans = $progress.children(), percent; $.each( percentages, function( k, v ) { total += v[ 0 ]; loaded += v[ 0 ] * v[ 1 ]; } ); percent = total ? loaded / total : 0; spans.eq( 0 ).text( Math.round( percent * 100 ) + '%' ); spans.eq( 1 ).css( 'width', Math.round( percent * 100 ) + '%' ); updateStatus(); } function updateStatus() { var text = '', stats; if ( state === 'ready' ) { text = '选中' + fileCount + '张图片,共' + WebUploader.formatSize( fileSize ) + ''; } else if ( state === 'confirm' ) { stats = uploader.getStats(); if ( stats.uploadFailNum ) { text = '已成功上传' + stats.successNum+ '张照片至XX相册,'+ stats.uploadFailNum + '张照片上传失败,<a class="retry" href="#">重新上传</a>失败图片或<a class="ignore" href="#">忽略</a>' } } else { stats = uploader.getStats(); text = '' + fileCount + '张(' + WebUploader.formatSize( fileSize ) + '),已上传' + stats.successNum + ''; if ( stats.uploadFailNum ) { text += ',失败' + stats.uploadFailNum + ''; } } $info.html( text ); } function setState( val ) { var file, stats; if ( val === state ) { return; } $upload.removeClass( 'state-' + state ); $upload.addClass( 'state-' + val ); state = val; switch ( state ) { case 'pedding': $placeHolder.removeClass( 'element-invisible' ); $queue.parent().removeClass('filled'); $queue.hide(); $statusBar.addClass( 'element-invisible' ); uploader.refresh(); break; case 'ready': $placeHolder.addClass( 'element-invisible' ); $( '#filePicker2' ).removeClass( 'element-invisible'); $queue.parent().addClass('filled'); $queue.show(); $statusBar.removeClass('element-invisible'); uploader.refresh(); break; case 'uploading': $( '#filePicker2' ).addClass( 'element-invisible' ); $progress.show(); $upload.text( '暂停上传' ); break; case 'paused': $progress.show(); $upload.text( '继续上传' ); break; case 'confirm': $progress.hide(); $upload.text( '开始上传' ).addClass( 'disabled' ); stats = uploader.getStats(); if ( stats.successNum && !stats.uploadFailNum ) { setState( 'finish' ); return; } break; case 'finish': stats = uploader.getStats(); if ( stats.successNum ) { $upload.text( '开始上传' ).removeClass( 'disabled' ); $( '#filePicker2' ).removeClass( 'element-invisible' ); alert( '上传成功' ); } else { // 没有成功的图片,重设 state = 'done'; location.reload(); } break; } updateStatus(); } uploader.onUploadProgress = function( file, percentage ) { var $li = $('#'+file.id), $percent = $li.find('.progress span'); $percent.css( 'width', percentage * 100 + '%' ); percentages[ file.id ][ 1 ] = percentage; updateTotalProgress(); }; uploader.onFileQueued = function( file ) { fileCount++; fileSize += file.size; if ( fileCount === 1 ) { $placeHolder.addClass( 'element-invisible' ); $statusBar.show(); } addFile( file ); setState( 'ready' ); updateTotalProgress(); }; uploader.onFileDequeued = function( file ) { fileCount--; fileSize -= file.size; if ( !fileCount ) { setState( 'pedding' ); } removeFile( file ); updateTotalProgress(); }; uploader.on( 'all', function( type ) { var stats; switch( type ) { case 'uploadFinished': setState( 'confirm' ); break; case 'startUpload': setState( 'uploading' ); break; case 'stopUpload': setState( 'paused' ); break; } }); //上传成功回调函数 uploader.on( 'uploadSuccess', function(files,response) { console.log(response); }); //错误提示 uploader.onError = function( code ) { if(code == "F_DUPLICATE"){ alert("系统提示:请不要重复选择文件!"); }else if(code == "Q_EXCEED_SIZE_LIMIT"){ alert("系统提示:<span class='C6'>所选附件总大小</span>不可超过<span class='C6'>" + allMaxSize + "M</span>哦!<br>换个小点的文件吧!"); }else{ alert( 'Eroor: ' + code ); } }; $upload.on('click', function() { if ( $(this).hasClass( 'disabled' ) ) { return false; } if ( state === 'ready' ) { uploader.upload(); } else if ( state === 'paused' ) { uploader.upload(); } else if ( state === 'uploading' ) { uploader.stop(); } }); $info.on( 'click', '.retry', function() { uploader.retry(); } ); $info.on( 'click', '.ignore', function() { alert( 'todo' ); } ); $upload.addClass( 'state-' + state ); updateTotalProgress(); });

    这里就差不多了,注意我画红色地方,webuploader文件上传地址和参数名(fileVal:参数名),webuploader文件上传成功回调函数,webuploader和上传时错误提示。

    资源路径:http://files.cnblogs.com/files/hz-cww/webuploader.rar

    官方api:http://fex.baidu.com/webuploader/doc/index.html

      

  • 相关阅读:
    敌兵布阵(线段树单点更新+区间查询)
    小明上学(CCF认证2018-12-1 )
    There Are Two Types Of Burgers (Educational Codeforces Round 71)
    Bad Prices ( Codeforces Round #582 )
    Redis热点key优化
    Redis big key处理
    Redis的安全问题
    Redis的flushall/flushdb误操作
    Redis在linux系统中的优化
    Redis之缓存设计
  • 原文地址:https://www.cnblogs.com/hz-cww/p/6284383.html
Copyright © 2011-2022 走看看