All Downloads are FREE. Search and download functionalities are using the official Maven repository.

static.admin.app.modules.zyupload.js Maven / Gradle / Ivy

There is a newer version: 1.2
Show newest version
;(function (factory) {
    if (typeof define === 'function' && define.amd) {
        // AMD. Register as an anonymous module.
        define(['jquery'], factory);
    } else if (typeof module === 'object' && module.exports) {
        // Node/CommonJS
        module.exports = function (root, jQuery) {
            if (jQuery === undefined) {
                // require('jQuery') returns a factory that requires window to
                // build a jQuery instance, we normalize how we use modules
                // that require this pattern but the window provided is a noop
                // if it's defined (how jquery works)
                if (typeof window !== 'undefined') {
                    jQuery = require('jquery');
                } else {
                    jQuery = require('jquery')(root);
                }
            }
            factory(jQuery);
            return jQuery;
        };
    } else if (window.layui && layui.define) {
        layui.define('jquery', function (exports) {
            exports('zyupload', factory(layui.jquery))
        }).link(webConfig.rootDir + 'res/zyupload/css/zyUpload.css');
    } else {
        // Browser globals
        factory(jQuery);
    }
}(function (jQuery) {

    var ZYFILE = {
        fileInput: null,             // 选择文件按钮dom对象
        uploadInput: null,           // 上传文件按钮dom对象
        dragDrop: null,				  // 拖拽敏感区域
        url: "",  					  // 上传action路径
        uploadFile: [],  			  // 需要上传的文件数组
        lastUploadFile: [],          // 上一次选择的文件数组,方便继续上传使用
        perUploadFile: [],           // 存放永久的文件数组,方便删除使用
        fileNum: 0,                  // 代表文件总个数,因为涉及到继续添加,所以下一次添加需要在它的基础上添加索引
        /* 提供给外部的接口 */
        filterFile: function (files) { // 提供给外部的过滤文件格式等的接口,外部需要把过滤后的文件返回
            return files;
        },
        onSelect: function (selectFile, files) {      // 提供给外部获取选中的文件,供外部实现预览等功能  selectFile:当前选中的文件  allFiles:还没上传的全部文件

        },
        onDelete: function (file, files) {            // 提供给外部获取删除的单个文件,供外部实现删除效果  file:当前删除的文件  files:删除之后的文件

        },
        onProgress: function (file, loaded, total) {  // 提供给外部获取单个文件的上传进度,供外部实现上传进度效果

        },
        onSuccess: function (file, responseInfo) {    // 提供给外部获取单个文件上传成功,供外部实现成功效果

        },
        onFailure: function (file, responseInfo) {    // 提供给外部获取单个文件上传失败,供外部实现失败效果

        },
        onComplete: function (responseInfo) {         // 提供给外部获取全部文件上传完成,供外部实现完成效果
            alert("上传成功");
        },

        /* 内部实现功能方法 */
        // 获得选中的文件
        //文件拖放
        funDragHover: function (e) {
            e.stopPropagation();
            e.preventDefault();
            this[e.type === "dragover" ? "onDragOver" : "onDragLeave"].call(e.target);
            return this;
        },
        // 获取文件
        funGetFiles: function (e) {
            var self = this;
            // 取消鼠标经过样式
            this.funDragHover(e);
            // 从事件中获取选中的所有文件
            var files = e.target.files || e.dataTransfer.files;
            self.lastUploadFile = this.uploadFile;
            this.uploadFile = this.uploadFile.concat(this.filterFile(files));
            var tmpFiles = [];

            // 因为jquery的inArray方法无法对object数组进行判断是否存在于,所以只能提取名称进行判断
            var lArr = [];  // 之前文件的名称数组
            var uArr = [];  // 现在文件的名称数组
            $.each(self.lastUploadFile, function (k, v) {
                lArr.push(v.name);
            });
            $.each(self.uploadFile, function (k, v) {
                uArr.push(v.name);
            });

            $.each(uArr, function (k, v) {
                // 获得当前选择的每一个文件   判断当前这一个文件是否存在于之前的文件当中
                if ($.inArray(v, lArr) < 0) {  // 不存在
                    tmpFiles.push(self.uploadFile[k]);
                }
            });

            // 如果tmpFiles进行过过滤上一次选择的文件的操作,需要把过滤后的文件赋值
            //if(tmpFiles.length!=0){
            this.uploadFile = tmpFiles;
            //}

            // 调用对文件处理的方法
            this.funDealtFiles();

            return true;
        },
        // 处理过滤后的文件,给每个文件设置下标
        funDealtFiles: function () {
            var self = this;
            // 目前是遍历所有的文件,给每个文件增加唯一索引值
            $.each(this.uploadFile, function (k, v) {
                // 因为涉及到继续添加,所以下一次添加需要在总个数的基础上添加
                v.index = self.fileNum;
                // 添加一个之后自增
                self.fileNum++;
            });
            // 先把当前选中的文件保存备份
            var selectFile = this.uploadFile;
            // 要把全部的文件都保存下来,因为删除所使用的下标是全局的变量
            this.perUploadFile = this.perUploadFile.concat(this.uploadFile);
            // 合并下上传的文件
            this.uploadFile = this.lastUploadFile.concat(this.uploadFile);

            // 执行选择回调
            this.onSelect(selectFile, this.uploadFile);
            console.info("继续选择");
            self.funUploadFiles();
            console.info(this.uploadFile);
            return this;
        },
        // 处理需要删除的文件  isCb代表是否回调onDelete方法
        // 因为上传完成并不希望在页面上删除div,但是单独点击删除的时候需要删除div   所以用isCb做判断
        funDeleteFile: function (delFileIndex, isCb) {
            var self = this;  // 在each中this指向没个v  所以先将this保留

            var tmpFile = [];  // 用来替换的文件数组
            // 合并下上传的文件
            var delFile = this.perUploadFile[delFileIndex];
            //console.info(delFile);
            // 目前是遍历所有的文件,对比每个文件  删除
            $.each(this.uploadFile, function (k, v) {
                if (delFile != v) {
                    // 如果不是删除的那个文件 就放到临时数组中
                    tmpFile.push(v);
                }
            });
            this.uploadFile = tmpFile;
            if (isCb) {  // 执行回调
                // 回调删除方法,供外部进行删除效果的实现
                self.onDelete(delFile, this.uploadFile);
            }

            console.info("还剩这些文件没有上传:");
            console.info(this.uploadFile);
            return true;
        },
        // 上传多个文件
        funUploadFiles: function () {
            var self = this;  // 在each中this指向没个v  所以先将this保留
            // 遍历所有文件  ,在调用单个文件上传的方法
            $.each(this.uploadFile, function (k, v) {
                self.funUploadFile(v);
            });
        },
        // 上传单个个文件
        funUploadFile: function (file) {
            var self = this;  // 在each中this指向没个v  所以先将this保留
            var formdata = new FormData();
            formdata.append("file", file);
            // 添加裁剪的坐标和宽高发送给后台
            if ($("#uploadTailor_" + file.index).length > 0) {
                // 除了这样获取不到zyUpload的值啊啊啊啊啊啊啊啊啊啊啊
                formdata.append("tailor", $("#uploadTailor_" + file.index).attr("tailor"));
            }
            var xhr = new XMLHttpRequest();
            // 绑定上传事件
            // 进度
            xhr.upload.addEventListener("progress", function (e) {
                // 回调到外部
                self.onProgress(file, e.loaded, e.total);
            }, false);
            // 完成
            xhr.addEventListener("load", function (e) {
                // 从文件中删除上传成功的文件  false是不执行onDelete回调方法
                self.funDeleteFile(file.index, false);
                // 回调到外部
                self.onSuccess(file, xhr.responseText);
                if (self.uploadFile.length == 0) {
                    // 回调全部完成方法
                    self.onComplete("全部完成");
                }
            }, false);
            // 错误
            xhr.addEventListener("error", function (e) {
                // 回调到外部
                self.onFailure(file, xhr.responseText);
            }, false);

            xhr.open("POST", self.url, true);
            xhr.send(formdata);
        },
        // 返回需要上传的文件
        funReturnNeedFiles: function () {
            return this.uploadFile;
        },

        // 初始化
        init: function () {  // 初始化方法,在此给选择、上传按钮绑定事件
            var self = this;  // 克隆一个自身

            if (this.dragDrop) {
                this.dragDrop.addEventListener("dragover", function (e) {
                    self.funDragHover(e);
                }, false);
                this.dragDrop.addEventListener("dragleave", function (e) {
                    self.funDragHover(e);
                }, false);
                this.dragDrop.addEventListener("drop", function (e) {
                    self.funGetFiles(e);
                }, false);
            }

            // 如果选择按钮存在
            if (self.fileInput) {
                // 绑定change事件
                this.fileInput.addEventListener("change", function (e) {
                    self.funGetFiles(e);
                }, false);
            }

            // 如果上传按钮存在
            if (self.uploadInput) {
                // 绑定click事件
                this.uploadInput.addEventListener("click", function (e) {
                    self.funUploadFiles(e);
                }, false);
            }
        }
    };

    (function ($, undefined) {
        $.fn.zyUpload = function (options, param) {
            var fileType = options.fileType;
            var otherArgs = Array.prototype.slice.call(arguments, 1);
            if (typeof options == 'string') {
                var fn = this[0][options];
                if ($.isFunction(fn)) {
                    return fn.apply(this, otherArgs);
                } else {
                    throw ("zyUpload - No such method: " + options);
                }
            }

            return this.each(function () {
                var para = {};    // 保留参数
                var self = this;  // 保存组件对象

                var defaults = {
                    width: "700px",  					      // 宽度
                    height: "400px",  					      // 宽度
                    itemWidth: "140px",                           // 文件项的宽度
                    itemHeight: "120px",                           // 文件项的高度
                    url: "albumUpload",  	      // 上传文件的路径
                    multiple: true,  						      // 是否可以多个文件上传
                    dragDrop: true,  						      // 是否可以拖动上传文件
                    del: true,  						      // 是否可以删除文件
                    edit: true,  						      // 是否可以重新上传文件
                    tailor: true,  						      // 是否可以截取图片
                    finishDel: false,  						      // 是否在上传文件完成后删除预览
                    /* 提供给外部的接口方法 */
                    onSelect: function (selectFiles, allFiles) {
                    }, // 选择文件的回调方法  selectFile:当前选中的文件  allFiles:还没上传的全部文件
                    onProgress: function (file, loaded, total) {
                    },   // 正在上传的进度的回调方法
                    onDelete: function (file, files) {
                    },           // 删除一个文件的回调方法 file:当前删除的文件  files:删除之后的文件
                    onSuccess: function (file, response) {
                    },        // 文件上传成功的回调方法
                    onFailure: function (file, response) {
                    },        // 文件上传失败的回调方法
                    onComplete: function (response) {
                    }               // 上传完成的回调方法
                };

                para = $.extend(defaults, options);

                this.init = function () {
                    this.createHtml();  // 创建组件html
                    this.createCorePlug();  // 调用核心js
                };

                /**
                 * 功能:创建上传所使用的html
                 * 参数: 无
                 * 返回: 无
                 */
                this.createHtml = function () {
                    var multiple = "";  // 设置多选的参数
                    para.multiple ? multiple = "multiple" : multiple = "";
                    var html = '';

                    if (para.dragDrop) {
                        // 创建带有拖动的html
                        html += '
'; html += '
'; html += '
'; html += '
'; html += '
'; html += '
'; html += '
点击选择文件并上传
'; html += ' '; html += '
'; html += '
'; html += '
'; html += ' '; html += ' '; html += '
'; html += '
'; html += ' '; html += '
'; html += '
'; html += '
'; html += '
'; } else { var imgWidth = parseInt(para.itemWidth.replace("px", "")) - 15; // 创建不带有拖动的html html += '
'; html += '
'; html += '
'; html += '
'; html += '
选中0张文件,共0B。
'; html += '
'; html += ' '; html += '
点击选择文件并上传
'; html += ' '; html += '
'; html += '
'; html += ' '; html += '
'; html += '
'; html += ' '; html += '
'; html += '
'; html += '
'; html += '
'; } $(self).append(html).css({"width": para.width, "height": para.height}); // 初始化html之后绑定按钮的点击事件 this.addEvent(); }; /** * 功能:显示统计信息和绑定继续上传和上传按钮的点击事件 * 参数: 无 * 返回: 无 */ this.funSetStatusInfo = function (files) { var size = 0; var num = files.length; $.each(files, function (k, v) { // 计算得到文件总大小 size += v.size; }); // 转化为kb和MB格式。文件的名字、大小、类型都是可以现实出来。 if (size > 1024 * 1024) { size = (Math.round(size * 100 / (1024 * 1024)) / 100).toString() + 'MB'; } else { size = (Math.round(size * 100 / 1024) / 100).toString() + 'KB'; } // 设置内容 $("#status_info").html("选中" + num + "张文件,共" + size + "。"); }; /** * 功能:过滤上传的文件格式等 * 参数: files 本次选择的文件 * 返回: 通过的文件 */ this.funFilterEligibleFile = function (files) { var arrFiles = []; // 替换的文件数组 for (var i = 0, file; file = files[i]; i++) { if (file.size >= 51200000) { alert('您这个"' + file.name + '"文件大小过大'); } else { // 在这里需要判断当前所有文件中 arrFiles.push(file); } } return arrFiles; }; /** * 功能: 处理参数和格式上的预览html * 参数: files 本次选择的文件 * 返回: 预览的html */ this.funDisposePreviewHtml = function (file, e) { var html = ""; var imgWidth = parseInt(para.itemWidth.replace("px", "")) - 15; var imgHeight = parseInt(para.itemHeight.replace("px", "")) - 10; // 处理配置参数编辑和删除按钮 var editHtml = ""; var delHtml = ""; if (para.edit) { // 显示编辑按钮 editHtml = ''; } if (para.del) { // 显示删除按钮 delHtml = ''; } // 处理不同类型文件代表的图标 var fileImgSrc = "control/images/fileType/"; if (file.type.indexOf("rar") > 0) { fileImgSrc = fileImgSrc + "rar.png"; } else if (file.type.indexOf("zip") > 0) { fileImgSrc = fileImgSrc + "zip.png"; } else if (file.type.indexOf("text") > 0) { fileImgSrc = fileImgSrc + "txt.png"; } else { fileImgSrc = fileImgSrc + "txt.png"; } // 图片上传的是图片还是其他类型文件 if (file.type.indexOf("image") == 0) { html += '
'; html += '
'; html += '
'; html += '

' + file.name + '

'; html += editHtml; // 编辑按钮的html html += delHtml; // 删除按钮的html html += '
'; html += '
'; html += ' '; html += '
'; html += ' '; html += '
'; html += '
'; html += '

'; html += '

上传失败,请重试

'; html += '

'; html += '

'; html += '
'; } else { html += '
'; html += '
'; html += '
'; html += '

' + file.name + '

'; html += delHtml; // 删除按钮的html html += '
'; html += '
'; html += ' '; html += '
'; html += ' '; html += '
'; html += '
'; html += '

'; html += '

上传失败,请重试

'; html += '

'; html += '
'; } return html; }; /** * 功能: 创建弹出层插件,会在其中进行裁剪操作 * 参数: imgSrc 当前裁剪图片的路径 * 返回: 无 */ this.createPopupPlug = function (imgSrc, index) { // 初始化裁剪插件 $("body").zyPopup({ src: imgSrc, // 图片的src路径 onTailor: function (val) { // 回调返回裁剪的坐标和宽高的值 $("#uploadTailor_" + index).show(); $.getScript("jquery.json-2.4.js", function () { $("#uploadTailor_" + index).attr("tailor", $.toJSON(val)); }); } }); }; /** * 功能:调用核心插件 * 参数: 无 * 返回: 无 */ this.createCorePlug = function () { var params = { fileInput: $("#fileImage").get(0), uploadInput: $("#fileSubmit").get(0), dragDrop: $("#fileDragArea").get(0), url: $("#uploadForm").attr("action"), filterFile: function (files) { // 过滤合格的文件 return self.funFilterEligibleFile(files); }, onSelect: function (selectFiles, allFiles) { para.onSelect(selectFiles, allFiles); // 回调方法 self.funSetStatusInfo(ZYFILE.funReturnNeedFiles()); // 显示统计信息 var html = '', i = 0; // 组织预览html var funDealtPreviewHtml = function () { file = selectFiles[i]; if (file) { var reader = new FileReader(); reader.onload = function (e) { // 处理下配置参数和格式的html html += self.funDisposePreviewHtml(file, e); i++; // 再接着调用此方法递归组成可以预览的html funDealtPreviewHtml(); } reader.readAsDataURL(file); } else { // 走到这里说明文件html已经组织完毕,要把html添加到预览区 funAppendPreviewHtml(html); } }; // 添加预览html var funAppendPreviewHtml = function (html) { // 添加到添加按钮前 if (para.dragDrop) { $("#preview").append(html); } else { $(".add_upload").before(html); } // 绑定删除按钮 funBindDelEvent(); funBindHoverEvent(); }; // 绑定删除按钮事件 var funBindDelEvent = function () { if ($(".file_del").length > 0) { // 删除方法 $(".file_del").click(function () { ZYFILE.funDeleteFile(parseInt($(this).attr("data-index")), true); return false; }); } if ($(".file_edit").length > 0) { if ($("head").html().indexOf("zyPopup") < 0) { // 代表没有加载过js和css文件 // 动态引入裁剪的js和css文件 $("").attr({ rel: "stylesheet", type: "text/css", /*href: "zyPopup/css/zyPopup.css"*/ }).appendTo("head"); /*$.getScript("zyPopup/js/zyPopup.js", function(){ // 编辑方法 $(".file_edit").click(function() { // 获取选择的文件索引 var imgSrc = $("#uploadImage_"+$(this).attr("data-index")).attr("src"); // 打开弹出层 self.createPopupPlug(imgSrc, $(this).attr("data-index")); return false; }); });*/ } else { // 加载过js和css文件 // 编辑方法 $(".file_edit").click(function () { // 获取选择的文件索引 var imgSrc = $("#uploadImage_" + $(this).attr("data-index")).attr("src"); // 打开弹出层 self.createPopupPlug(imgSrc, $(this).attr("data-index")); return false; }); } } }; // 绑定显示操作栏事件 var funBindHoverEvent = function () { $(".upload_append_list").hover( function (e) { $(this).find(".file_bar").addClass("file_hover"); }, function (e) { $(this).find(".file_bar").removeClass("file_hover"); } ); }; funDealtPreviewHtml(); }, onDelete: function (file, files) { para.onDelete(file, files); // 回调方法 // 移除效果 $("#uploadList_" + file.index).fadeOut(); // 重新设置统计栏信息 self.funSetStatusInfo(files); console.info("剩下的文件"); console.info(files); }, onProgress: function (file, loaded, total) { para.onProgress(file, loaded, total); // 回调方法 var eleProgress = $("#uploadProgress_" + file.index), percent = (loaded / total * 100).toFixed(2) + '%'; if (eleProgress.is(":hidden")) { eleProgress.show(); } eleProgress.css("width", percent); }, onSuccess: function (file, response) { para.onSuccess(file, response); // 回调方法 $("#uploadProgress_" + file.index).hide(); $("#uploadSuccess_" + file.index).show(); /*$("#uploadInf").append("

上传成功,文件地址是:" + response + "

");*/ // 根据配置参数确定隐不隐藏上传成功的文件 if (para.finishDel) { // 移除效果 $("#uploadList_" + file.index).fadeOut(); // 重新设置统计栏信息 self.funSetStatusInfo(ZYFILE.funReturnNeedFiles()); } if ($("#uploadTailor_" + file.index).length > 0) { $("#uploadTailor_" + file.index).hide(); } }, onFailure: function (file, response) { para.onFailure(file, response); // 回调方法 $("#uploadProgress_" + file.index).hide(); $("#uploadSuccess_" + file.index).show(); if ($("#uploadTailor_" + file.index).length > 0) { $("#uploadTailor_" + file.index).hide(); } $("#uploadInf").append("

文件" + file.name + "上传失败!

"); //$("#uploadImage_" + file.index).css("opacity", 0.2); }, onComplete: function (response) { para.onComplete(response); // 回调方法 console.info(response); }, onDragOver: function () { $(this).addClass("upload_drag_hover"); }, onDragLeave: function () { $(this).removeClass("upload_drag_hover"); } }; ZYFILE = $.extend(ZYFILE, params); ZYFILE.init(); }; /** * 功能:绑定事件 * 参数: 无 * 返回: 无 */ this.addEvent = function () { // 如果快捷添加文件按钮存在 if ($(".filePicker").length > 0) { // 绑定选择事件 $(".filePicker").bind("click", function (e) { var id = $('input[name="id"]').val(); if (id != undefined && id != '') { $.tip.info('重新上传图片会替换之前的图片!'); } $("#fileImage").click(); }); } // 绑定继续添加点击事件 // $(".webuploader_pick").bind("click", function(e){ // $("#fileImage").click(); // }); // 绑定上传点击事件 $(".upload_btn").bind("click", function (e) { // 判断当前是否有文件需要上传 if (ZYFILE.funReturnNeedFiles().length > 0) { $("#fileSubmit").click(); } // else{ // $.alert({ // title: '警告', // content: '请先选择照片再上传哦!', // confirmButton: '确定' // }); // } }); // 如果快捷添加文件按钮存在 if ($("#rapidAddImg").length > 0) { // 绑定添加点击事件 $("#rapidAddImg").bind("click", function (e) { $("#fileImage").click(); }); } }; // 初始化上传控制层插件 this.init(); }); }; })(jQuery); (function ($) { $.fn.zupload = function (options) { this.zyUpload({ width: options.width, height: options.height, itemWidth: "120px", itemHeight: "100px", url: "", multiple: true, dragDrop: true, del: true, finishDel: false, onSelect: function (selectFiles, allFiles) { console.info("当前选择了以下文件:"); console.info(selectFiles); }, onProgress: function (file, loaded, total) { // 正在上传的进度的回调方法 console.info("当前正在上传此文件:"); console.info(file.name); console.info("进度等信息如下:"); console.info(loaded); console.info(total); }, onDelete: function (file, files) { // 删除一个文件的回调方法 file:当前删除的文件 files:删除之后的文件 console.info("当前删除了此文件:"); console.info(file.name); }, onSuccess: function (file, response) { // 文件上传成功的回调方法 console.info("此文件上传成功:"); console.info(file.name); }, onFailure: function (file, response) { // 文件上传失败的回调方法 console.info("此文件上传失败:"); console.info(file.name); }, onComplete: function (response) { // 上传完成的回调方法 console.info("文件上传完成"); console.info(response); } }); }; })(jQuery); }));




© 2015 - 2024 Weber Informatics LLC | Privacy Policy