webuploader上传文件,大小,类型,提示、和一些错误

使用webuploader上传图片,对格式大小有限制。
下面是我是用中的一些总结,有不对的地方,希望大佬们指出。这里写图片描述
废话不多说,下面正文
文件大小限制

fileNumLimit: xx,//上传数量限制
fileSizeLimit: xx,//限制上传所有文件大小
fileSingleSizeLimit: xx,//限制上传单个文件大小

图片类型限制

accept: {// 只允许选择图片文件格式
    title: 'Images',
    extensions: 'gif,jpg,bmp,png',
    mimeTypes: 'image/*'
},

提示信息
type是错误编码。不清楚的错误可以打印出来看一下,使用的layer弹出提示、可以改的。

/**
* 验证文件格式以及文件大小
*/
uploader.on("error", function (type) {
    if (type == "Q_TYPE_DENIED") {
        layer.msg("请上传JPG、PNG、GIF、BMP格式文件");
    } else if (type == "Q_EXCEED_SIZE_LIMIT") {
        layer.msg("文件大小不能超过2M");
    }else {
            layer.msg("上传出错!请检查后重新上传!错误代码"+type);
    }
});

一些错误

我碰到还一种情况是要初始化的空间隐藏状态,控件没有初始化。解决方法是在控件显示出来后在调用一次函数,就是在初始化一次。

单张图片上传完后,想要修改再次上传图片是没有效果,我在网上查找到了 说加上duplicate: true
但是我的还是没有效果,解决方法是上传完成后再次初始化控件。

源码如下,有明白问什么都同学还请告知一二。
下面贴出全部代码。仅供参考

/**
 * @param url 地址
 * @param num 上传数量
 * @param totalSize 限制上传所有文件大小
 * @param singleSize 限制上传单个文件大小
 */
function initWebuploader(url,num,totalSize,singleSize,rootPath) {
    uploader = WebUploader.create({
        fileNumLimit: num,//上传数量限制
        fileSizeLimit: totalSize,//限制上传所有文件大小
        fileSingleSizeLimit: singleSize,//限制上传单个文件大小
        auto: true,
        // swf文件路径
        // swf: BASE_URL + '/js/Uploader.swf',
        // 文件接收服务端。
        server: url,
        // 选择文件的按钮。可选。
        // 内部根据当前运行是创建,可能是input元素,也可能是flash.
        pick: '#picker',
        // 不压缩image, 默认如果是jpeg,文件上传前会压缩一把再上传!
        resize: false,
        accept: {// 只允许选择图片文件格式
         title: 'Images',
         extensions: 'gif,jpg,bmp,png',
         mimeTypes: 'image/*'
         },
        duplicate: true
    });
    //上传每个文件之前设置额外参数
    uploader.on("uploadStart", function () {
    });
    uploader.on("startUpload", function () {
    });
    uploader.on("uploadSuccess", function (file, response) {
        $("#imgView").attr("src", rootPath + response);
        $("#photo").val(response);
        layer.msg("上传成功");
    });
    uploader.on("uploadFinished", function () {
        //layer.msg("上传成功")
        //多次上传,页面使用webuploader1来调用,实现多次上传效果
        // function initWebuploader1() {
         //    initWebuploader(...);
        // }
        uploader.destroy();
        initWebuploader(url,num,totalSize,singleSize,rootPath);
    });
    /**
     * 验证文件格式以及文件大小
     */
    uploader.on("error", function (type) {
        if (type == "Q_TYPE_DENIED") {
            layer.msg("请上传JPG、PNG、GIF、BMP格式文件");
        } else if (type == "Q_EXCEED_SIZE_LIMIT") {
            layer.msg("文件大小不能超过2M");
        }else {
            layer.msg("上传出错!请检查后重新上传!错误代码"+type);
        }

    });
}

你可能感兴趣的:(js)