(function(window, document) { //定义上传类 var Cupload = function(options,document) { //初始化 new对象 if (!(this instanceof Cupload)) { return new Cupload(options) } //设置默认参数 this.localValue = { ele: '#cupload', name: 'image', num: 1, width: 148, height: 148, } //参数覆盖 this.opt = this.extend(this.localValue, options, true); this.document = document; //所需变量 this.i = 0; this.imageArr = new Array();//图片 this.widthArr = new Array();//图片宽度 this.heightArr = new Array();//图片高度 this.imageBox = new Array();//图片盒子 this.imagePreview = new Array();//图片预览 this.imageInput = new Array();//图片input this.imageDelete = new Array();//图片删除遮罩 this.deleteBtn = new Array();//图片删除按钮 this.sortLeftBtn = new Array();//图片左排序按钮 this.sortRightBtn = new Array();//图片右排序按钮 if ((typeof options.ele) === "string") { this.opt.ele = this.document.querySelector(options.ele) } else { this.opt.ele = options.ele } // 初始化为空 this.opt.ele.innerHTML = ""; this.initDom(); } Cupload.prototype = { constructor: this, //初始化 initDom: function() { this.cteateImageList() //查看是不需要上传 if(this.opt.model != "formview"){ this.createUploadBox() } this.createOverlay() if (this.opt.data) { this.showImagePreview() } }, //参数覆盖 extend: function(o, n, override) { for (var key in n) { if (n.hasOwnProperty(key) && (!o.hasOwnProperty(key) || override)) { o[key] = n[key] } } return o }, //创建图片列表 cteateImageList: function() { // this.imageList = this.document.createElement('ul') this.imageList = this.document.createElement('span') this.imageList.className = 'cupload-image-list' // this.imageList.style.margin = 0 // this.imageList.style.padding = 0 // this.imageList.style.display = 'inline-block' this.imageList.style.minHeight = this.opt.height this.opt.ele.appendChild(this.imageList) // this.imageList.ondragstart = function(event) { // console.log('start') // } }, //创建上传框 createUploadBox: function() { this.uploadBox = this.document.createElement('span') this.uploadBox.className = 'cupload-upload-box' // this.uploadBox.style.position = 'relative' // this.uploadBox.style.display = 'inline-block' // this.uploadBox.style.textAlign = 'center' // this.uploadBox.style.backgroundColor = '#fbfdff' // this.uploadBox.style.border = '1px dashed #c0ccda' // this.uploadBox.style.borderRadius = '6px' // this.uploadBox.style.WebkitBoxSizing = 'border-box' // this.uploadBox.style.boxSizing = 'border-box' this.uploadBox.style.width = this.opt.width + 'px' this.uploadBox.style.height = this.opt.height + 'px' this.uploadBox.style.lineHeight = this.opt.height + 'px' this.opt.ele.appendChild(this.uploadBox) this.createUploadBtn() this.createUploadInput() var _this = this this.uploadBox.onmouseover = function() { _this.uploadBox.style.borderColor = '#409eff' } this.uploadBox.onmouseout = function() { _this.uploadBox.style.borderColor = '#c0ccda' } }, //创建遮罩 createOverlay: function() { // this.overlay = this.document.createElement('div') this.overlay = this.document.createElement('span') this.overlay.className = 'cupload-overlay' // this.overlay.style.display = "none" // this.overlay.style.position = "fixed" // this.overlay.style.textAlign = "center" // this.overlay.style.top = 0 // this.overlay.style.right = 0 // this.overlay.style.bottom = 0 // this.overlay.style.left = 0 // this.overlay.style.zIndex = 9115 // this.overlay.style.backgroundColor = "rgba(0,0,0,.3)" this.document.body.appendChild(this.overlay) // this.opt.ele.appendChild(this.overlay) var _this = this this.overlay.onclick = function() { _this.zoomOutImage() } }, //创建上传按钮 createUploadBtn: function() { this.uploadBtn = this.document.createElement('span') this.uploadBtn.className = 'cupload-upload-btn' // this.uploadBtn.style.position = 'absolute' this.uploadBtn.style.left = this.opt.width/2 - 14 + 'px' // this.uploadBtn.style.fontSize = '28px' // this.uploadBtn.style.color = '#8c939d' this.uploadBtn.innerHTML = '+' this.uploadBox.appendChild(this.uploadBtn) }, //创建上传input createUploadInput: function() { this.uploadInput = this.document.createElement('input') this.uploadInput.className = 'cupload-upload-input' // this.uploadInput.style.position = 'absolute' // this.uploadInput.style.top = 0 // this.uploadInput.style.right = 0 // this.uploadInput.style.width = '100%' // this.uploadInput.style.height = '100%' // this.uploadInput.style.opacity = 0 // this.uploadInput.style.cursor = 'pointer' this.uploadInput.type = 'file' this.uploadInput.multiple = 'multiple' this.uploadInput.accept = 'image/*' this.uploadInput.title = '' this.uploadBox.appendChild(this.uploadInput) var _this = this this.uploadInput.onchange = function() { _this.removeUploadBox() _this.uploadImage() } }, //上传图片 uploadImage: function() { if(this.uploadInput.files.length + this.imageList.children.length > this.opt.num) { this.createUploadBox() alert('图片数量超出限制,请重新选择') return } for(j = 0; j < this.uploadInput.files.length; j++){ var file = this.uploadInput.files[j] if (!file || this.limitedSize(file)) { this.createUploadBox() return false } var reader = new FileReader() var _this = this reader.filename = file.name; reader.onload = function(e) { _this.limitedWidthAndHeight(e.target.result, e.target.filename,file) } reader.readAsDataURL(file); } if (this.uploadInput.files.length + this.imageList.children.length < this.opt.num) { this.createUploadBox() } }, //检测图片大小限制 limitedSize: function(file) { if (this.opt.minSize && file.size < this.opt.minSize * 1024) { alert('图片' + file.name + '大小未到最小限制,请重新选择') return true } if (this.opt.maxSize && file.size > this.opt.maxSize * 1024) { alert('图片' + file.name + '大小超出最大限制,请重新选择') return true } if (this.opt.limitedSize && file.size > this.opt.limitedSize * 1024) { alert('图片' + file.name + '大小不符合要求,请重新选择') return true } return false }, //检测图片像素限制 limitedWidthAndHeight: function(src, name,file) { var tempImage = new Image() tempImage.src = src var _this = this tempImage.onload = function() { if (_this.opt.minWidth && this.width < _this.opt.minWidth) { alert('图片' + name + '宽度未到最小限制,请重新选择') _this.isCreateUploadBox() return false } if (_this.opt.minHeight && this.height < _this.opt.minHeight) { alert('图片' + name + '高度未到最小限制,请重新选择') _this.isCreateUploadBox() return false } if (_this.opt.maxWidth && this.width > _this.opt.maxWidth) { alert('图片' + name + '宽度超出最大限制,请重新选择') _this.isCreateUploadBox() return false } if (_this.opt.maxHeight && this.height > _this.opt.maxHeight) { alert('图片' + name + '高度超出最大限制,请重新选择') _this.isCreateUploadBox() return false } if (_this.opt.limitedWidth && this.width != _this.opt.limitedWidth) { alert('图片' + name + '宽度不符合要求,请重新选择') _this.isCreateUploadBox() return false } if (_this.opt.limitedHeight && this.height != _this.opt.limitedHeight) { alert('图片' + name + '高度不符合要求,请重新选择') _this.isCreateUploadBox() return false } _this.foreachNum(src, name, this.width, this.height,file) } }, //检测图片数量 foreachNum: function(src, name, width, height,file) { if(this.opt.url) { // var key = this.opt.name // var data = {} // data[key] = src var _this = this this.ajaxUploadImage(file, function(res) { // console.log(res) _this.createImageBox(res.data.url, res.data.name, width, height); }) } else { this.createImageBox(src, name, width, height) } }, //图片异步上传 ajaxUploadImage: function(data,success) { let _this = this; let formData = new FormData(); formData.append("file", data); $.ajax({ url: _this.opt.url, type: "post", data: formData, processData: false, contentType: false, cache: false, success: function(res) { success(res) }, error: function(res) { } }); // var xhr = null; // if(window.XMLHttpRequest){ // xhr = new XMLHttpRequest() // } else { // xhr = new ActiveXObject('Microsoft.XMLHTTP') // } // if(typeof data == 'object'){ // var str = ''; // for(var key in data){ // str += key+'='+data[key]+'&'; // } // data = str.replace(/&$/, ''); // } // xhr.open('POST', this.opt.url, true); // xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); // xhr.send(data); // xhr.onreadystatechange = function(){ // if(xhr.readyState == 4){ // if(xhr.status == 200){ // success(xhr) // } else { // alert(((xhr.responseText).split("

")[0]).split("

")[1]) // return false // } // } // } }, //创建图片框 createImageBox: function(src, name, width, height, state = true) { this.imageArr[this.i] = src this.widthArr[this.i] = width this.heightArr[this.i] = height // this.imageBox[this.i] = this.document.createElement('li') this.imageBox[this.i] = this.document.createElement('span') this.imageBox[this.i].className = 'cupload-image-box' this.imageBox[this.i].setAttribute("seq",this.i); // this.imageBox[this.i].style.position = 'relative' // this.imageBox[this.i].style.display = 'inline-block' // this.imageBox[this.i].style.marginRight = 8 + 'px' // this.imageBox[this.i].style.backgroundColor = '#fbfdff' // this.imageBox[this.i].style.border = '1px solid #c0ccda' // this.imageBox[this.i].style.borderRadius = '6px' // this.imageBox[this.i].style.WebkitBoxSizing = 'border-box' // this.imageBox[this.i].style.boxSizing = 'border-box' this.imageBox[this.i].style.width = this.opt.width + 'px' this.imageBox[this.i].style.height = this.opt.height + 'px' this.imageList.appendChild(this.imageBox[this.i]) this.createImagePreview(src, width, height) if (!state) { this.setDefaultImage() } this.createImageInput(src) this.createImageDelete(name) var _this = this for (var m = 0; m <= this.i; m++) { this.imageBox[m].index = m this.imageBox[m].onmouseover = function(n) { return function() { _this.showImageDelete(n) } }(m) this.imageBox[m].onmouseout = function(n) { return function() { _this.hideImageDelete(n) } }(m) } this.i++ }, //创建图片预览框 createImagePreview: function(src, width, height) { this.imagePreview[this.i] = this.document.createElement('img') this.imagePreview[this.i].className = 'cupload-image-preview' // this.imagePreview[this.i].style.position = 'absolute' // this.imagePreview[this.i].style.top = 0 // this.imagePreview[this.i].style.left = 0 // this.imagePreview[this.i].style.right = 0 // this.imagePreview[this.i].style.bottom = 0 // this.imagePreview[this.i].style.margin = 'auto' this.imagePreview[this.i].src = src this.setImageAttribute(width, height) this.imageBox[this.i].appendChild(this.imagePreview[this.i]) }, //创建图片input createImageInput: function(src) { this.imageInput[this.i] = this.document.createElement('input') this.imageInput[this.i].type = 'hidden' this.imageInput[this.i].name = this.opt.name + '[]' this.imageInput[this.i].value = src this.imageBox[this.i].appendChild(this.imageInput[this.i]) }, //创建删除 createImageDelete: function(name) { this.imageDelete[this.i] = this.document.createElement('span') this.imageDelete[this.i].className = 'cupload-image-delete' // this.imageDelete[this.i].style.position = 'absolute' // this.imageDelete[this.i].style.width = '100%' // this.imageDelete[this.i].style.height = '100%' // this.imageDelete[this.i].style.left = 0 // this.imageDelete[this.i].style.top = 0 // this.imageDelete[this.i].style.textAlign = 'center' // this.imageDelete[this.i].style.color = '#fff' // this.imageDelete[this.i].style.opacity = 0 // this.imageDelete[this.i].style.cursor = 'zoom-in' // this.imageDelete[this.i].style.backgroundColor = 'rgba(0,0,0,.5)' // this.imageDelete[this.i].style.WebkitTransition = '.3s' // this.imageDelete[this.i].style.transition = '.3s' this.imageDelete[this.i].title = name this.imageBox[this.i].appendChild(this.imageDelete[this.i]) // 查看时不需要创建 if(this.opt.model != "formview"){ this.createDeleteBtn() this.createSortBtn() } var _this = this for (var m = 0; m <= this.i; m++) { this.imageDelete[m].onclick = function(n) { return function() { _this.zoomInImage(n) } }(m) } }, //创建删除按钮 createDeleteBtn: function() { this.deleteBtn[this.i] = this.document.createElement('span') this.deleteBtn[this.i].className = 'cupload-delete-btn' // this.deleteBtn[this.i].style.position = 'absolute' // this.deleteBtn[this.i].style.top = 0 // this.deleteBtn[this.i].style.right = 0 // this.deleteBtn[this.i].style.margin = 0 // this.deleteBtn[this.i].style.padding = 0 // this.deleteBtn[this.i].style.fontSize = '18px' // this.deleteBtn[this.i].style.width = '24px' // this.deleteBtn[this.i].style.height = '24px' // this.deleteBtn[this.i].style.cursor = 'pointer' // this.deleteBtn[this.i].style.backgroundImage = "url('')" // this.deleteBtn[this.i].style.backgroundSize = '18px 18px' // this.deleteBtn[this.i].style.backgroundRepeat = 'no-repeat' // this.deleteBtn[this.i].style.backgroundPosition = 'right top' this.deleteBtn[this.i].innerHTML = '' this.deleteBtn[this.i].title = '删除' this.imageDelete[this.i].appendChild(this.deleteBtn[this.i]) var _this = this for (var m = 0; m <= this.i; m++) { this.deleteBtn[m].onclick = function(n) { return function() { _this.deleteImage(n) } }(m) } }, createSortBtn: function() { this.sortLeftBtn[this.i] = this.document.createElement('span') this.sortLeftBtn[this.i].className = 'cupload-sort-left' // this.sortLeftBtn[this.i].style.position = 'absolute' // this.sortLeftBtn[this.i].style.bottom = 0 // this.sortLeftBtn[this.i].style.left = 0 // this.sortLeftBtn[this.i].style.margin = 0 // this.sortLeftBtn[this.i].style.padding = 0 // this.sortLeftBtn[this.i].style.fontSize = '18px' // this.sortLeftBtn[this.i].style.width = '24px' // this.sortLeftBtn[this.i].style.height = '24px' // this.sortLeftBtn[this.i].style.cursor = 'pointer' // this.sortLeftBtn[this.i].style.backgroundImage = "url('')" // this.sortLeftBtn[this.i].style.backgroundSize = '18px 18px' // this.sortLeftBtn[this.i].style.backgroundRepeat = 'no-repeat' // this.sortLeftBtn[this.i].style.backgroundPosition = 'left bottom' this.sortLeftBtn[this.i].innerHTML = '' this.sortLeftBtn[this.i].title = '左移' this.imageDelete[this.i].appendChild(this.sortLeftBtn[this.i]) this.sortRightBtn[this.i] = this.document.createElement('span') this.sortRightBtn[this.i].className = 'cupload-sort-right' // this.sortRightBtn[this.i].style.position = 'absolute' // this.sortRightBtn[this.i].style.bottom = 0 // this.sortRightBtn[this.i].style.right = 0 // this.sortRightBtn[this.i].style.margin = 0 // this.sortRightBtn[this.i].style.padding = 0 // this.sortRightBtn[this.i].style.fontSize = '18px' // this.sortRightBtn[this.i].style.width = '24px' // this.sortRightBtn[this.i].style.height = '24px' // this.sortRightBtn[this.i].style.cursor = 'pointer' // this.sortRightBtn[this.i].style.backgroundImage = "url('')" // this.sortRightBtn[this.i].style.backgroundSize = '18px 18px' // this.sortRightBtn[this.i].style.backgroundRepeat = 'no-repeat' // this.sortRightBtn[this.i].style.backgroundPosition = 'right bottom' this.sortRightBtn[this.i].innerHTML = '' this.sortRightBtn[this.i].title = '右移' this.imageDelete[this.i].appendChild(this.sortRightBtn[this.i]) var _this = this for (var m = 0; m <= this.i; m++) { this.sortLeftBtn[m].onclick = function(n) { return function() { _this.sortLeft(event, n) } }(m) this.sortRightBtn[m].onclick = function(n) { return function() { _this.sortRight(event, n) } }(m) } }, //设置默认图片 setDefaultImage: function() { this.imageBox[this.i].style.backgroundColor = "#B2B2B2" this.imageDelete[this.i].title = '图片不存在' this.imagePreview[this.i].src = '' if (130 / this.opt.width > 105 / this.opt.height) { this.imagePreview[this.i].style.width = this.opt.width - 2 + 'px' this.imagePreview[this.i].style.height = 105 / (130 / this.opt.width) - 2 + 'px' } else { this.imagePreview[this.i].style.width = 130 / (105 / this.opt.height) - 2 + 'px' this.imagePreview[this.i].style.height = this.opt.height - 2 + 'px' } }, //设置图片宽高 setImageAttribute: function(width, height) { if (width / this.opt.width > height / this.opt.height) { this.imagePreview[this.i].style.width = this.opt.width - 2 + 'px' this.imagePreview[this.i].style.height = height / (width / this.opt.width) - 2 + 'px' } else { this.imagePreview[this.i].style.width = width / (height / this.opt.height) - 2 + 'px' this.imagePreview[this.i].style.height = this.opt.height - 2 + 'px' } }, //data图片预览 showImagePreview: function() { var obj = this.opt.data if (obj.length >= this.opt.num) { this.removeUploadBox() } var _this = this var tempImage = new Image() tempImage.src = obj[this.i] tempImage.onload = function() { _this.createImageBox(obj[_this.i], obj[_this.i], this.width, this.height) setTimeout(function() { if (obj[_this.i]) { _this.showImagePreview() } }, 0); } tempImage.onerror = function() { _this.createImageBox(obj[_this.i], obj[_this.i], 0, 0, false) setTimeout(function() { if (obj[_this.i]) { _this.showImagePreview() } }, 0); } }, //图片放大预览 zoomInImage: function(n) { if(event.target.classList[0] === 'cupload-delete-btn' || event.target.classList[0] === 'cupload-sort-right' || event.target.classList[0] === 'cupload-sort-left') { return; } if(this.imagePreview[n].src == '') { alert('图片不存在') return; } // console.log(this.document) // console.log(this.document) this.zommImage = this.document.createElement('img') this.zommImage.className = 'cupload-overlay-img'; // this.zommImage.style.display = "inline-block" // this.zommImage.style.verticalAlign = "middle" this.zommImage.src = this.imageArr[n] if (this.widthArr[n] / window.innerWidth > this.heightArr[n] / window.innerHeight) { this.zommImage.style.width = 0.8 * window.innerWidth + 'px' this.zommImage.style.height = 0.8 * this.heightArr[n] / (this.widthArr[n] / window.innerWidth) + 'px' } else { this.zommImage.style.width = 0.8 * this.widthArr[n] / (this.heightArr[n] / window.innerHeight) + 'px' this.zommImage.style.height = 0.8 * window.innerHeight + 'px' } this.overlay.appendChild(this.zommImage) this.overlay.style.lineHeight = window.innerHeight + 'px' this.overlay.style.cursor = "zoom-out" this.overlay.style.display = "block" }, //关闭图片放大预览 zoomOutImage: function() { this.overlay.style.display = "none" this.zommImage.remove() }, //检测当前图片数量,判断是否创建上传框 isCreateUploadBox: function() { this.removeUploadBox() if (this.imageList.children.length < this.opt.num) { this.createUploadBox() } }, //删除图片 deleteImage: function(n) { this.imageBox[n].remove() this.removeUploadBox() if (this.imageList.children.length < this.opt.num) { this.createUploadBox() } if(this.opt.deleteUrl) { var xhr = null; var key = this.opt.name var data = {} data[key] = this.imageArr[n] if(window.XMLHttpRequest){ xhr = new XMLHttpRequest() } else { xhr = new ActiveXObject('Microsoft.XMLHTTP') } if(typeof data == 'object'){ var str = ''; for(var key in data){ str += key+'='+data[key]+'&'; } data = str.replace(/&$/, ''); } xhr.open('POST', this.opt.deleteUrl, true); xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); xhr.send(data); xhr.onreadystatechange = function(){ if(xhr.readyState == 4){ if(xhr.status == 200){ console.log(xhr.response) } else { alert(((xhr.responseText).split("

")[0]).split("

")[1]) return false } } } } }, sortLeft: function(event, n) { if(this.imageBox[n].previousSibling) { this.imageList.insertBefore(this.imageBox[n], this.imageBox[n].previousSibling) } }, sortRight: function(event, n) { if(this.imageBox[n].nextSibling) { this.imageList.insertBefore(this.imageBox[n].nextSibling, this.imageBox[n]) } }, //移除上传框 removeUploadBox: function() { this.uploadBox.remove() }, //显示图片删除 showImageDelete: function(m) { this.imageDelete[m].style.opacity = 1 }, //隐藏图片删除 hideImageDelete: function(m) { this.imageDelete[m].style.opacity = 0 }, } //初始化 Cupload.init = function(ue){ // 初始化上传图片 let imgUploads = ue.document.querySelectorAll("a[datatype='imgUpload']"); // console.log(imgUploads) if(imgUploads){ imgUploads.forEach((child) => { // 是否存在批注 let note = child.querySelector(".note"); // 判断是否存在图片,有的话初始化 let imgs = child.querySelectorAll("img.cupload-image-preview"); // console.log(imgs) let imgSrcs = null; if(imgs && imgs.length > 0){ imgSrcs = []; imgs.forEach((img) => { imgSrcs.push(img.src); }); } // console.log(imgSrcs) let id = child.getAttribute("cupload"); let imgNum = child.getAttribute("imageNum"); AttrA.imgUploads[id] = new Cupload ({ ele: '#'+id, num: imgNum, model: ue.options.model, url : url+"/api/v1/emreditor/imgUpload", data: imgSrcs },ue.document); // 存在批注则添加到元素中 if(note){ child.prepend(note); } }) } // console.log(AttrA.imgUploads) } window.Cupload = Cupload; })(window, document)