123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822 |
- (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: 178,
- height: 183,
- }
- //参数覆盖
- 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();//图片右排序按钮
- this.rolateBtn = new Array();//旋转图片按钮
- this.imageRolate = 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("</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] = 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)
- //remove by chenqiwang
- //this.imageBox[this.i].appendChild(this.imagePreview[this.i])
- //add div
- let imgDiv = this.document.createElement('div');
- let imgRmk = this.document.createElement('a');
- imgRmk.className = "input";
- imgRmk.setAttribute("contenteditable","true");
- imgDiv.className = "cupload-image-div"
- imgDiv.appendChild(this.imagePreview[this.i])
- imgDiv.appendChild(imgRmk);
- this.imageBox[this.i].appendChild(imgDiv)
- },
- //创建图片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()
- this.createRolateBtn();//add by chenqiwang
- }
- 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)
- }
- },
- //创建删除按钮
- createRolateBtn: function() {
- this.rolateBtn[this.i] = this.document.createElement('span')
- this.rolateBtn[this.i].className = 'cupload-rolate-btn'
- this.rolateBtn[this.i].innerHTML = ''
- this.rolateBtn[this.i].title = '旋转'
- this.imageDelete[this.i].appendChild(this.rolateBtn[this.i])
- var _this = this
- for (var m = 0; m <= this.i; m++) {
- this.rolateBtn[m].onclick = function(n) {
- return function() {
- _this.rolateImage(event,n)
- }
- }(m)
- }
- },
- rolateImage: function(event, n){
- event.cancelBubble = true;
- // event.stopImmediatePropagation();
- this.rotateBase64Img(this.imagePreview[n],this.imagePreview[n].src,90);
- },
- rotateBase64Img : async(imgObj,src, edg) => {
- const canvas = document.createElement('canvas')
- const ctx = canvas.getContext('2d')
- let imgW// 图片宽度
- let imgH// 图片高度
- let size// canvas初始大小
- if (edg % 90 != 0) {
- console.error('旋转角度必须是90的倍数!')
- }
- (edg < 0) && (edg = (edg % 360) + 360)
- const quadrant = (edg / 90) % 4 // 旋转象限
- const cutCoor = { sx: 0, sy: 0, ex: 0, ey: 0 } // 裁剪坐标
- const image = new Image()
- image.crossOrigin = 'anonymous'
- image.src = src
- image.onload = await function() {
- debugger;
- imgW = image.width
- imgH = image.height
- size = imgW > imgH ? imgW : imgH
- canvas.width = size * 2
- canvas.height = size * 2
- switch (quadrant) {
- case 0:
- cutCoor.sx = size
- cutCoor.sy = size
- cutCoor.ex = size + imgW
- cutCoor.ey = size + imgH
- break
- case 1:
- cutCoor.sx = size - imgH
- cutCoor.sy = size
- cutCoor.ex = size
- cutCoor.ey = size + imgW
- break
- case 2:
- cutCoor.sx = size - imgW
- cutCoor.sy = size - imgH
- cutCoor.ex = size
- cutCoor.ey = size
- break
- case 3:
- cutCoor.sx = size
- cutCoor.sy = size - imgW
- cutCoor.ex = size + imgH
- cutCoor.ey = size + imgW
- break
- }
- ctx.translate(size, size)
- ctx.rotate(edg * Math.PI / 180)
- ctx.drawImage(image, 0, 0)
- var imgData = ctx.getImageData(cutCoor.sx, cutCoor.sy, cutCoor.ex, cutCoor.ey)
- if (quadrant % 2 == 0) {
- canvas.width = imgW
- canvas.height = imgH
- } else {
- canvas.width = imgH
- canvas.height = imgW
- }
- ctx.putImageData(imgData, 0, 0)
- imgObj.src = canvas.toDataURL()
- // this.imagePreview[n].src = canvas.toDataURL();
- // 获取旋转后的base64图片
- //state.esignImg = canvas.toDataURL()
- //state.showEsign = false
- }
- },
- 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'
- // }
- this.imagePreview[this.i].style.width = (this.opt.width - 10) + 'px'
- this.imagePreview[this.i].style.height = (this.opt.height - 10) + '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("</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
- },
- }
- //初始化
- 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)
|