|
- (function(window, document) {
-
- //定义上传类
- var Cupload = function(options) {
-
- //初始化 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.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 = document.querySelector(options.ele)
- } else {
- this.opt.ele = options.ele
- }
-
- this.initDom();
- }
-
- Cupload.prototype = {
- constructor: this,
-
- //初始化
- initDom: function() {
- this.cteateImageList()
- 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 = document.createElement('ul')
- 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 = document.createElement('div')
- 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 = '#007b76'
- }
- this.uploadBox.onmouseout = function() {
- _this.uploadBox.style.borderColor = '#c0ccda'
- }
- },
-
- //创建遮罩
- createOverlay: function() {
- this.overlay = document.createElement('div')
- 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.opt.ele.appendChild(this.overlay)
- var _this = this
- this.overlay.onclick = function() {
- _this.zoomOutImage()
- }
- },
-
- //创建上传按钮
- createUploadBtn: function() {
- this.uploadBtn = 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 = 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)
- }
- 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) {
- 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)
- }
- },
-
- //检测图片数量
- foreachNum: function(src, name, width, height) {
- if(this.opt.url) {
- var key = this.opt.name
- var data = {}
- data[key] = src
- var _this = this
- this.ajaxUploadImage(data, function(res) {
- _this.createImageBox(res.responseText, res.responseText, width, height)
- })
- } else {
- this.createImageBox(src, name, width, height)
- }
- },
-
- //图片异步上传
- ajaxUploadImage: function(data,success) {
- 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("</p>")[0]).split("<p>")[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] = document.createElement('li')
- this.imageBox[this.i].className = 'cupload-image-box'
- 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 #007b76'
- 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)
- this.createImageInput(src)
- this.createImageDelete(name)
- if (!state) {
- this.setDefaultImage()
- }
- 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] = 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] = 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] = document.createElement('div')
- 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])
- 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] = 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] = 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] = 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;
- }
- this.zommImage = document.createElement('img')
- this.zommImage.style.display = "inline-block"
- this.zommImage.style.verticalAlign = "middle"
- this.zommImage.style.position= "absolute";
- this.zommImage.style.top="50%";
- this.zommImage.style.transform="translate(-50%,-50%)";
- 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("</p>")[0]).split("<p>")[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
- },
- }
-
- window.Cupload = Cupload;
- })(window, document)
|