import Vue from 'vue'
|
|
Vue.directive('draw', {
|
inserted: function (el, binding, vNode) {
|
const minWidth = 200
|
const minHeight = 200
|
el.setAttribute('style', 'position: fixed; z-index: 9999;max-height:' + (document.body.clientHeight - 100) + "px")
|
el.onmousemove = function (e) {
|
// let moveE = e
|
if (
|
e.clientX > el.offsetLeft + el.clientWidth - 10 ||
|
el.offsetLeft + 10 > e.clientX
|
) {
|
el.style.cursor = 'w-resize'
|
} else if (
|
el.scrollTop + e.clientY >
|
el.offsetTop + el.clientHeight - 10
|
) {
|
el.style.cursor = 's-resize'
|
} else {
|
el.style.cursor = 'default'
|
|
el.onmousedown = null
|
}
|
el.onmousedown = e => {
|
const clientX = e.clientX
|
const clientY = e.clientY
|
const elW = el.clientWidth
|
const elH = el.clientHeight
|
const EloffsetLeft = el.offsetLeft
|
const EloffsetTop = el.offsetTop
|
el.style.userSelect = 'none'
|
const ELscrollTop = el.scrollTop
|
// 判断点击的位置是不是为头部
|
if (
|
clientX > EloffsetLeft &&
|
clientX < EloffsetLeft + elW &&
|
clientY > EloffsetTop &&
|
clientY < EloffsetTop + 50
|
) {
|
|
// 如果是头部在此就不做任何动作,以上有绑定dialogHeaderEl.onmousedown = moveDown;
|
} else {
|
document.onmousemove = function (e) {
|
// 移动时禁用默认事件
|
e.preventDefault()
|
// 左侧鼠标拖拽位置
|
if (clientX > EloffsetLeft - 5 && clientX < EloffsetLeft + 5) {
|
// 往左拖拽
|
if (clientX > e.clientX) {
|
el.style.width = elW + (clientX - e.clientX) + 'px'
|
}
|
// 往右拖拽
|
if (clientX < e.clientX) {
|
if (el.clientWidth < minWidth) {
|
console.log()
|
} else {
|
el.style.width = elW - (e.clientX - clientX) + 'px'
|
}
|
}
|
}
|
// 右侧鼠标拖拽位置
|
if (
|
clientX > EloffsetLeft + elW - 5 &&
|
clientX < EloffsetLeft + elW + 5
|
) {
|
// 往左拖拽
|
if (clientX > e.clientX) {
|
if (el.clientWidth < minWidth) {
|
console.log()
|
} else {
|
el.style.width = elW - (clientX - e.clientX) + 'px'
|
}
|
}
|
// 往右拖拽
|
if (clientX < e.clientX) {
|
el.style.width = elW + (e.clientX - clientX) + 'px'
|
}
|
}
|
// 底部鼠标拖拽位置
|
if (
|
ELscrollTop + clientY > EloffsetTop + elH - 10 &&
|
ELscrollTop + clientY < EloffsetTop + elH + 10
|
) {
|
// 往上拖拽
|
if (clientY > e.clientY) {
|
if (el.clientHeight < minHeight) {
|
console.log()
|
} else {
|
el.style.height = elH - (clientY - e.clientY) + 'px'
|
}
|
}
|
// 往下拖拽
|
if (clientY < e.clientY) {
|
el.style.height = elH + (e.clientY - clientY) + 'px'
|
}
|
}
|
}
|
// 拉伸结束
|
document.onmouseup = function (e) {
|
document.onmousemove = null
|
|
document.onmouseup = null
|
}
|
}
|
}
|
}
|
},
|
bind: function (el, bindding, vNode) {
|
el.setAttribute('draggable', true)
|
let left, top, width, height
|
el._dragstart = function (event) {
|
event.stopPropagation()
|
left = event.clientX - el.offsetLeft
|
top = event.clientY - el.offsetTop
|
width = el.offsetWidth
|
height = el.offsetHeight
|
}
|
el._checkPosition = function () { // 防止被拖出边界
|
let width = el.offsetWidth
|
let height = el.offsetHeight
|
let left = Math.min(el.offsetLeft, document.body.clientWidth - width)
|
left = Math.max(0, left)
|
let top = Math.min(el.offsetTop, document.body.clientHeight - height)
|
top = Math.max(0, top)
|
el.style.left = left + 'px'
|
el.style.top = top + 'px'
|
el.style.width = width + 'px'
|
el.style.height = height + 'px'
|
}
|
el._dragEnd = function (event) {
|
event.stopPropagation()
|
left = event.clientX - left
|
top = event.clientY - top
|
el.style.left = left + 'px'
|
el.style.top = top + 'px'
|
el.style.width = width + 'px'
|
el.style.height = height + 'px'
|
el._checkPosition()
|
}
|
el._documentAllowDraop = function (event) {
|
event.preventDefault()
|
}
|
document.body.addEventListener('dragover', el._documentAllowDraop)
|
el.addEventListener('dragstart', el._dragstart)
|
el.addEventListener('dragend', el._dragEnd)
|
window.addEventListener('resize', el._checkPosition)
|
},
|
|
unbind: function (el, bindding, vNode) {
|
document.body.removeEventListener('dragover', el._documentAllowDraop)
|
el.removeEventListener('dragstart', el._dragstart)
|
el.removeEventListener('dragend', el._dragEnd)
|
window.removeEventListener('resize', el._checkPosition)
|
delete el._documentAllowDraop
|
delete el._dragstart
|
delete el._dragEnd
|
delete el._checkPosition
|
}
|
})
|
|
// // v-dialogDrag: 弹窗拖拽
|
// Vue.directive('dialogDrag', {
|
// bind(el, binding, vnode, oldVnode) {
|
// const dialogHeaderEl = el.querySelector('.el-dialog__header')
|
// const dragDom = el.querySelector('.el-dialog')
|
// dialogHeaderEl.style.cursor = 'move'
|
|
// // 获取原有属性 ie dom元素.currentStyle 火狐谷歌 window.getComputedStyle(dom元素, null);
|
// const sty = dragDom.currentStyle || window.getComputedStyle(dragDom, null)
|
|
// dialogHeaderEl.onmousedown = (e) => {
|
// // 鼠标按下,计算当前元素距离可视区的距离
|
// const disX = e.clientX - dialogHeaderEl.offsetLeft
|
// const disY = e.clientY - dialogHeaderEl.offsetTop
|
|
// // 获取到的值带px 正则匹配替换
|
// let styL, styT
|
|
// // 注意在ie中 第一次获取到的值为组件自带50% 移动之后赋值为px
|
// if (sty.left.includes('%')) {
|
// styL = +document.body.clientWidth * (+sty.left.replace(/\%/g, '') / 100)
|
// styT = +document.body.clientHeight * (+sty.top.replace(/\%/g, '') / 100)
|
// } else {
|
// styL = +sty.left.replace(/\px/g, '')
|
// styT = +sty.top.replace(/\px/g, '')
|
// }
|
|
// document.onmousemove = function (e) {
|
// // 通过事件委托,计算移动的距离
|
// const l = e.clientX - disX
|
// const t = e.clientY - disY
|
|
// // 移动当前元素
|
// dragDom.style.left = `${l + styL}px`
|
// dragDom.style.top = `${t + styT}px`
|
|
// // 将此时的位置传出去
|
// // binding.value({x:e.pageX,y:e.pageY})
|
// }
|
|
// document.onmouseup = function (e) {
|
// document.onmousemove = null
|
// document.onmouseup = null
|
// }
|
// }
|
// }
|
// })
|
|
// // v-dialogDragWidth: 弹窗宽度拖大 拖小
|
// Vue.directive('dialogDragWidth', {
|
// bind(el, binding, vnode, oldVnode) {
|
// const dragDom = binding.value.$el.querySelector('.el-dialog')
|
|
// el.onmousedown = (e) => {
|
// // 鼠标按下,计算当前元素距离可视区的距离
|
// const disX = e.clientX - el.offsetLeft
|
|
// document.onmousemove = function (e) {
|
// e.preventDefault() // 移动时禁用默认事件
|
|
// // 通过事件委托,计算移动的距离
|
// const l = e.clientX - disX
|
// dragDom.style.width = `${l}px`
|
// }
|
|
// document.onmouseup = function (e) {
|
// document.onmousemove = null
|
// document.onmouseup = null
|
// }
|
// }
|
// }
|
// })
|
|
|
// /*
|
// * 使用方法
|
// * 将以下代码复制到一个drag.js文件中,然后在入口文件main.js中导入:import ‘./util/drog.js’;
|
// * 给elementUI的dialog上加上 v-dialogDrag 指令就可以实现弹窗的全屏和拉伸了。
|
// * 给dialog设置 :close-on-click-modal="false" , 禁止点击遮罩层关闭弹出层
|
// * 如果是form表单,不要将提交等按钮放置el-form-item,以免在上下拉伸时被隐藏
|
// */
|
// // v-dialogDrag: 弹窗拖拽+水平方向伸缩
|
// export default {
|
// bind(el, binding, vnode) {
|
// const minWidth = 1000
|
// const minHeight = 620
|
// const dialogHeaderEl = el.querySelector('.el-dialog__header')
|
// const dragDom = el.querySelector('.el-dialog')
|
// dialogHeaderEl.style.cssText += ';cursor:move;'
|
// dragDom.style.cssText += ';top:0px;'
|
// // 获取原有属性 ie dom元素.currentStyle 火狐谷歌 window.getComputedStyle(dom元素, null);
|
// const getStyle = (function () {
|
// if (window.document.currentStyle) {
|
// return (dom, attr) => dom.currentStyle[attr]
|
// } else {
|
// return (dom, attr) => getComputedStyle(dom, false)[attr]
|
// }
|
// })()
|
// const moveDown = (e) => {
|
// // 鼠标按下,计算当前元素距离可视区的距离
|
// const disX = e.clientX - dialogHeaderEl.offsetLeft
|
// const disY = e.clientY - dialogHeaderEl.offsetTop
|
// const dragDomWidth = dragDom.offsetWidth
|
// const dragDomHeight = dragDom.offsetHeight
|
|
// const screenWidth = document.body.clientWidth
|
// const screenHeight = document.body.clientHeight
|
|
// const minDragDomLeft = dragDom.offsetLeft
|
// const maxDragDomLeft = screenWidth - dragDom.offsetLeft - dragDomWidth
|
|
// const minDragDomTop = dragDom.offsetTop
|
// const maxDragDomTop = screenHeight - dragDom.offsetTop - dragDomHeight
|
|
// // 获取到的值带px 正则匹配替换
|
// let styL = getStyle(dragDom, 'left')
|
// let styT = getStyle(dragDom, 'top')
|
|
// if (styL.includes('%')) {
|
// styL = +document.body.clientWidth * (+styL.replace(/\%/g, '') / 100)
|
// styT = +document.body.clientHeight * (+styT.replace(/\%/g, '') / 100)
|
// } else {
|
// styL = +styL.replace(/\px/g, '')
|
// styT = +styT.replace(/\px/g, '')
|
// }
|
|
// document.onmousemove = function (e) {
|
// // 通过事件委托,计算移动的距离
|
// let left = e.clientX - disX
|
// let top = e.clientY - disY
|
|
// // 边界处理
|
// if (-(left) > minDragDomLeft) {
|
// left = -minDragDomLeft
|
// } else if (left > maxDragDomLeft) {
|
// left = maxDragDomLeft
|
// }
|
|
// if (-(top) > minDragDomTop) {
|
// top = -minDragDomTop
|
// } else if (top > maxDragDomTop) {
|
// top = maxDragDomTop
|
// }
|
|
// // 移动当前元素
|
// dragDom.style.cssText += `;left:${left + styL}px;top:${top + styT}px;`
|
|
// // emit onDrag event
|
// vnode.child.$emit('dragDialog')
|
// }
|
|
// document.onmouseup = function (e) {
|
// document.onmousemove = null
|
// document.onmouseup = null
|
// }
|
// }
|
// // 当前宽高
|
// let nowWidth = 0
|
// dialogHeaderEl.onmousedown = moveDown
|
// dragDom.onmousemove = function (e) {
|
// // let moveE = e
|
// if (
|
// e.clientX > dragDom.offsetLeft + dragDom.clientWidth - 10 ||
|
// dragDom.offsetLeft + 10 > e.clientX
|
// ) {
|
// dragDom.style.cursor = 'w-resize'
|
// } else if (
|
// el.scrollTop + e.clientY >
|
// dragDom.offsetTop + dragDom.clientHeight - 10
|
// ) {
|
// dragDom.style.cursor = 's-resize'
|
// } else {
|
// dragDom.style.cursor = 'default'
|
|
// dragDom.onmousedown = null
|
// }
|
// dragDom.onmousedown = e => {
|
// const clientX = e.clientX
|
// const clientY = e.clientY
|
// const elW = dragDom.clientWidth
|
// const elH = dragDom.clientHeight
|
// const EloffsetLeft = dragDom.offsetLeft
|
// const EloffsetTop = dragDom.offsetTop
|
// dragDom.style.userSelect = 'none'
|
// const ELscrollTop = el.scrollTop
|
// // 判断点击的位置是不是为头部
|
// if (
|
// clientX > EloffsetLeft &&
|
// clientX < EloffsetLeft + elW &&
|
// clientY > EloffsetTop &&
|
// clientY < EloffsetTop + 100
|
// ) {
|
// // 如果是头部在此就不做任何动作,以上有绑定dialogHeaderEl.onmousedown = moveDown;
|
// } else {
|
// document.onmousemove = function (e) {
|
// // 移动时禁用默认事件
|
// e.preventDefault()
|
// // 左侧鼠标拖拽位置
|
// if (clientX > EloffsetLeft && clientX < EloffsetLeft + 10) {
|
// // 往左拖拽
|
// if (clientX > e.clientX) {
|
// dragDom.style.width = elW + (clientX - e.clientX) * 2 + 'px'
|
// }
|
// // 往右拖拽
|
// if (clientX < e.clientX) {
|
// if (dragDom.clientWidth < minWidth) {
|
// console.log()
|
// } else {
|
// dragDom.style.width = elW - (e.clientX - clientX) * 2 + 'px'
|
// }
|
// }
|
// }
|
// // 右侧鼠标拖拽位置
|
// if (
|
// clientX > EloffsetLeft + elW - 10 &&
|
// clientX < EloffsetLeft + elW
|
// ) {
|
// // 往左拖拽
|
// if (clientX > e.clientX) {
|
// if (dragDom.clientWidth < minWidth) {
|
// console.log()
|
// } else {
|
// dragDom.style.width = elW - (clientX - e.clientX) * 2 + 'px'
|
// }
|
// }
|
// // 往右拖拽
|
// if (clientX < e.clientX) {
|
// dragDom.style.width = elW + (e.clientX - clientX) * 2 + 'px'
|
// }
|
// }
|
// // 底部鼠标拖拽位置
|
// if (
|
// ELscrollTop + clientY > EloffsetTop + elH - 20 &&
|
// ELscrollTop + clientY < EloffsetTop + elH
|
// ) {
|
// // 往上拖拽
|
// if (clientY > e.clientY) {
|
// if (dragDom.clientHeight < minHeight) {
|
// console.log()
|
// } else {
|
// dragDom.style.height = elH - (clientY - e.clientY) * 2 + 'px'
|
// }
|
// }
|
// // 往下拖拽
|
// if (clientY < e.clientY) {
|
// dragDom.style.height = elH + (e.clientY - clientY) * 2 + 'px'
|
// }
|
// }
|
// }
|
// // 拉伸结束
|
// document.onmouseup = function (e) {
|
// document.onmousemove = null
|
|
// document.onmouseup = null
|
// }
|
// }
|
// }
|
// }
|
// }
|
// }
|