博客
关于我
Vue 项目中使用拖拽弹框 dragdialog, 弹框拖拽缩放,拖拽排序等
阅读量:176 次
发布时间:2019-02-28

本文共 1185 字,大约阅读时间需要 3 分钟。

在开发Element UI项目时,需要实现弹框的拖拽和缩放功能。以下是优化后的实现方案,涵盖了拖拽排序和缩放的完整逻辑。

拖拽排序实现

拖拽排序通过拖拽弹框标题栏实现,逻辑如下:

  • 事件监听:在弹框标题栏上绑定mousedown事件,计算初始拖拽位置。
  • 跟踪鼠标移动:使用mousemove事件跟踪鼠标位置,计算当前位置相对于弹框的偏移量。
  • 边界处理:确保弹框不会超出可视区域,调整偏移量为合理范围。
  • 更新位置:通过cssText更新弹框的lefttop属性,并触发自定义事件dragDialog
  • 缩放实现

    缩放功能通过在弹框右下角添加拖拽缩放标记实现,逻辑如下:

  • 拖拽触发:点击缩放标记,开始缩放操作。
  • 计算偏移量:计算鼠标移动相对于弹框的偏移量。
  • 比例处理:根据宽高比调整宽度和高度,确保缩放后的弹框符合比例要求。
  • 范围限制:根据最小宽、高和最大宽、高限制缩放范围,避免超出设定值。
  • 更新样式:通过cssText更新弹框的宽度和高度,并触发自定义事件dragDialogHeight
  • 组件使用

    在主组件中使用自定义指令:

    CSS样式优化

    确保弹框和缩放标记样式正确:

    .el-dialog {  margin: 0 auto;}.mouse {  position: absolute;  right: 0;  bottom: 0;  cursor: se-resize;  width: 10px;  height: 10px;  background: #666;  z-index: 999;}

    代码优化

    修复自定义指令,确保逻辑正确:

    Vue.directive('dialogDrag', {  bind(el, binding) {    if (!binding.value) return;    const dialogHeaderEl = el.querySelector('.el-dialog__header');    const dragDom = el.querySelector('.el-dialog');    dialogHeaderEl.style.cursor = 'move';    dragDom.style.position = 'fixed';    dragDom.style.top = '150px';    // 其他初始化逻辑...  },  unbind() {    // 解绑事件...  }});

    注意事项

    • 事件处理:确保mousemovemouseup事件在松开鼠标时被正确清除,以防内存泄漏。
    • 浏览器兼容:如有需要,可以添加IE兼容代码,确保跨浏览器适配。
    • 数据更新:确保在缩放时,数据绑定正确更新,避免状态不一致。

    通过以上优化,可以实现可拖拽、可缩放的弹框组件,满足开发需求。

    转载地址:http://pewn.baihongyu.com/

    你可能感兴趣的文章
    Objective-C实现double hash双哈希算法(附完整源码)
    查看>>
    Objective-C实现double linear search recursion双线性搜索递归算法(附完整源码)
    查看>>
    Objective-C实现double linear search 双线性搜索算法(附完整源码)
    查看>>
    Objective-C实现double sort双重排序算法(附完整源码)
    查看>>
    Objective-C实现DoublyLinkedList双链表的算法(附完整源码)
    查看>>
    Objective-C实现DoublyLinkedList双链表算法(附完整源码)
    查看>>
    Objective-C实现DPLL(davisb putnamb logemannb loveland)算法(附完整源码)
    查看>>
    Objective-C实现DWT离散小波变换(附完整源码)
    查看>>
    Objective-C实现Edmonds-Karp算法(附完整源码)
    查看>>
    Objective-C实现EEMD算法(附完整源码)
    查看>>
    Objective-C实现elgamal 密钥生成器算法(附完整源码)
    查看>>
    Objective-C实现EM算法(附完整源码)
    查看>>
    Objective-C实现EM算法(附完整源码)
    查看>>
    Objective-C实现entropy熵算法(附完整源码)
    查看>>
    Objective-C实现euclidean distance欧式距离算法(附完整源码)
    查看>>
    Objective-C实现Euclidean GCD欧几里得最大公约数算法(附完整源码)
    查看>>
    Objective-C实现euclideanDistance欧氏距离算法(附完整源码)
    查看>>
    Objective-C实现euler method欧拉法算法(附完整源码)
    查看>>
    Objective-C实现euler modified变形欧拉法算法(附完整源码)
    查看>>
    Objective-C实现eulerianPath欧拉路径算法(附完整源码)
    查看>>