webuploader 上传文件 可删除的

本文介绍了一种使用WebUploader实现在网页上进行单个文件上传,并能够覆盖之前上传文件的方法。通过设置文件个数限制为1,确保每次只上传一个文件,同时利用上传前的事件监听器移除上次上传的文件项,达到覆盖的效果。代码示例包括HTML结构、JS逻辑和样式设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  • 实现效果:*
  • 单个文件 上传的文件可以覆盖上次的文件*

1 .html 样式

<div class="uploader-demo">
    <!--用来存放item-->
    <div id="thelist" class="uploader-list"></div>
    <div class="btns">
        <div id="picker">选择文件</div>
    </div>
</div>

2 .js 代码

// 文件上传demo
    $(function () {
        var $ = jQuery,
            $list = $('#thelist'),
            // 优化retina, 在retina下这个值是2
            ratio = 1 || 1,

            // 缩略图大小
            thumbnailWidth = 100 * ratio,
            thumbnailHeight = 100 * ratio,

            // 初始化Web Uploader
            uploader = WebUploader.create({
                // 选完文件后,是否自动上传。
                auto: true,
                // swf文件路径
                swf: '/content/plugins/webuploader/Uploader.swf',
                // 文件个数限制
                fileNumLimit: 1,
                // 文件接收服务端。
                server: getRootPath() + '/uploadFileReturnModel',
                // 选择文件的按钮。可选。
                // 内部根据当前运行是创建,可能是input元素,也可能是flash.
                pick: '#picker',
                formData: {
                    destDir: "fileInfo"
                },
                // 不压缩image
                resize: false
            });

        uploader.on('fileQueued', function (file) {
            $list.append('<div id="' + file.id + '" class="item">' +
                '<h4 class="info">' + file.name + '</h4>' +
                '<p class="state">等待上传...</p>' +
                '</div>');
            //console.log(file);
            var fileStatusnum = uploader.getStats();
            if (fileStatusnum.cancelNum > 0){
                // 多文件上传  列队的时候上传上个文件的样式
                $('#WU_FILE_'+(fileStatusnum.cancelNum-1)).remove();
            }
        });
        // 文件上传过程中创建进度条实时显示。
        uploader.on('uploadProgress', function (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 + '%');
        });
        // 文件上传成功,给item添加成功class, 用样式标记上传成功。
        uploader.on('uploadSuccess', function (file, response) {
            $('#' + file.id).find('p.state').text('已上传');
            //photoList.push(JSON.parse(response._raw));
            //$("#photo").val(JSON.stringify(photoList));
            $("#fujian").val(response._raw);
            var fileStatusnum = uploader.getStats();
            // $.fn.modalMsg("上传成功"+fileStatusnum.successNum+"个文件","success");
            $.fn.modalMsg("上传成功", "success");
            // 上传成功在缓存里上传文件
            uploader.removeFile(file);
            $('#' + file.id).addClass('upload-state-done-file');
        });

        // 文件上传失败,显示上传出错。
        uploader.on('uploadError', function (file) {
            $('#' + file.id).find('p.state').text('上传出错');

            var fileStatusnum = uploader.getStats();
            layer.msg("上传失败" + fileStatusnum.uploadFailNum + "个文件", {icon: 1, time: 1000});
        });

        // 完成上传完了,成功或者失败,先删除进度条。
        uploader.on('uploadComplete', function (file) {
            $('#' + file.id).find('.progress').fadeOut();
        });

    });
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值