编写基础js,取名叫drag.js

    1. export default {
    2. bind(el, binding, vnode) {
    3. const dialogHeaderEl = el.querySelector('.el-dialog__header')
    4. const dragDom = el.querySelector('.el-dialog')
    5. dialogHeaderEl.style.cursor = 'move'
    6. dragDom.style.cssText += ';top:0px;'
    7. // 获取原有属性 ie dom元素.currentStyle 火狐谷歌 window.getComputedStyle(dom元素, null);
    8. const getStyle = (function() {
    9. if (window.document.currentStyle) {
    10. return (dom, attr) => dom.currentStyle[attr]
    11. } else {
    12. return (dom, attr) => getComputedStyle(dom, false)[attr]
    13. }
    14. })()
    15. dialogHeaderEl.onmousedown = (e) => {
    16. // 鼠标按下,计算当前元素距离可视区的距离
    17. const disX = e.clientX - dialogHeaderEl.offsetLeft
    18. const disY = e.clientY - dialogHeaderEl.offsetTop
    19. const screenWidth = document.body.clientWidth
    20. const screenHeight = document.body.clientHeight
    21. const minDragDomLeft = dragDom.offsetLeft
    22. const maxDragDomLeft = screenWidth - dragDom.offsetLeft
    23. const minDragDomTop = dragDom.offsetTop
    24. const maxDragDomTop = screenHeight - dragDom.offsetTop
    25. // 获取到的值带px 正则匹配替换
    26. let styL = getStyle(dragDom, 'left')
    27. let styT = getStyle(dragDom, 'top')
    28. if (styL.includes('%')) {
    29. styL = +document.body.clientWidth * (+styL.replace(/\%/g, '') / 100)
    30. styT = +document.body.clientHeight * (+styT.replace(/\%/g, '') / 100)
    31. } else {
    32. styL = +styL.replace(/px/g, '')
    33. styT = +styT.replace(/px/g, '')
    34. }
    35. document.onmousemove = function(e) {
    36. // 通过事件委托,计算移动的距离
    37. let left = e.clientX - disX
    38. let top = e.clientY - disY
    39. // 边界处理
    40. if (-(left) > minDragDomLeft) {
    41. left = -minDragDomLeft
    42. } else if (left > maxDragDomLeft) {
    43. left = maxDragDomLeft
    44. }
    45. if (-(top) > minDragDomTop) {
    46. top = -minDragDomTop
    47. } else if (top > maxDragDomTop) {
    48. top = maxDragDomTop
    49. }
    50. // 移动当前元素
    51. dragDom.style.cssText += `;left:${left + styL}px;top:${top + styT}px;`
    52. }
    53. document.onmouseup = function(e) {
    54. document.onmousemove = null
    55. document.onmouseup = null
    56. }
    57. }
    58. }
    59. }

    编辑外层使用的指令文件,取名叫el-drag-dialog.js

    1. import drag from './drag'
    2. const install = function(Vue) {
    3. Vue.directive('el-drag-dialog', drag)
    4. }
    5. if (window.Vue) {
    6. window['el-drag-dialog'] = drag
    7. Vue.use(install); // eslint-disable-line
    8. }
    9. drag.install = install
    10. export default drag

    在vue组件中使用

    1. <el-dialog v-el-drag-dialog></el-dialog>
    1. import elDragDialog from '@/directive/el-drag-dialog'
    2. directives: { elDragDialog },