当前位置: 首页 > news >正文

Element UI el-dialog自由拖动功能

1.创建drag .js文件

/*** 拖拽移动* @param  {elementObjct} bar 鼠标点击控制拖拽的元素* @param {elementObjct}  target 移动的元素* @param {function}  callback 移动后的回调*/
export function startDrag(bar, target, callback) {var params = {top: 0,left: 0,currentX: 0,currentY: 0,flag: false,cWidth: 0,cHeight: 0,tWidth: 0,tHeight: 0};// 给拖动块添加样式bar.style.cursor = 'move';// 获取相关CSS属性// o是移动对象// var getCss = function (o, key) {//   return o.currentStyle ? o.currentStyle[key] :             document.defaultView.getComputedStyle(o, false)[key];// };bar.onmousedown = function (event) {// 按下时初始化paramsvar e = event ? event : window.event;params = {top: target.offsetTop,left: target.offsetLeft,currentX: e.clientX,currentY: e.clientY,flag: true,cWidth: document.body.clientWidth,cHeight: document.body.clientHeight,tWidth: target.offsetWidth,tHeight: target.offsetHeight};// 给被拖动块初始化样式target.style.margin = 0;target.style.top = params.top + 'px';target.style.left = params.left + 'px';if (!event) {// 防止IE文字选中bar.onselectstart = function () {return false;}}document.onmousemove = function (event) {// 防止文字选中window.getSelection ? window.getSelection().removeAllRanges() : document.selection.empty();var e = event ? event : window.event;if (params.flag) {var nowX = e.clientX;var nowY = e.clientY;// 差异距离var disX = nowX - params.currentX;var disY = nowY - params.currentY;// 最终移动位置var zLeft = 0;var zTop = 0;zLeft = parseInt(params.left) + disX;// 限制X轴范围if (zLeft <= -parseInt(params.tWidth / 2)) {zLeft = -parseInt(params.tWidth / 2);}if (zLeft >= params.cWidth - parseInt(params.tWidth * 0.5)) {zLeft = params.cWidth - parseInt(params.tWidth * 0.5);}zTop = parseInt(params.top) + disY;// 限制Y轴范围if (zTop <= 0) {zTop = 0;}if (zTop >= params.cHeight - parseInt(params.tHeight * 0.5)) {zTop = params.cHeight - parseInt(params.tHeight * 0.5);}// 执行移动target.style.left = zLeft + 'px';target.style.top = zTop + 'px';}if (typeof callback == "function") {callback(zLeft, zTop);}}document.onmouseup = function () {params.flag = false;document.onmousemove = null;document.onmouseup = null;};};}

2.创建directive.js 文件

// 引入拖拽js
import { startDrag } from './drag.js'/*** 为el-dialog弹框增加拖拽功能* @param {*} el 指定dom* @param {*} binding 绑定对象* desc   只要用到了el-dialog的组件,都可以通过增加v-draggable属性变为可拖拽的弹框*/
const draggable = (el, binding) => {// 绑定拖拽事件 [绑定拖拽触发元素为弹框头部、拖拽移动元素为整个弹框]startDrag(el.querySelector('.el-dialog__header'), el.querySelector('.el-dialog'), binding.value);
};const directives = {draggable,
};
// 这种写法可以批量注册指令
export default {install(Vue) {Object.keys(directives).forEach((key) => {Vue.directive(key, directives[key]);});},
};

3.main.js文件中全局引入vue指令

import directive from './utils/directive'
Vue.use(directive)

4.使用v-draagble

<el-dialog title="查看订单" :visible.sync="users" width="50%" v-draggable>

参考链接:添加链接描述

http://www.lryc.cn/news/324427.html

相关文章:

  • RPC浅析,加密数据解析
  • 光速论文能用吗 #媒体#知识分享#学习方法
  • 智慧工地解决方案,智慧工地项目管理系统源码,支持大屏端、PC端、手机端、平板端
  • 【前端寻宝之路】学习和使用label标签
  • 项目————网络聊天室
  • 【计算机网络】基本概念
  • Redis入门到实战-第七弹
  • 图像处理学习笔记(一)
  • duckdb学习-1
  • GEE高阶案例——Landsat/Sentinel/MODIS影像进行缨帽变换一行代码实现
  • 数独游戏(c++题解)
  • 【开发方案】Android 应用双卡搜网功能
  • 图论基础|深度优先dfs、广度优先bfs
  • Python从入门到精通秘籍十七
  • Java——抽象类和接口
  • React—— props校验(非typescript校验类型)
  • Go——map操作及原理
  • 网络安全实训Day9
  • kubernetes实战(1)之虚拟机centos搭建k8s集群
  • 基于python+vue分类信息服务平台移动端的设计与实现flask-django-php-nodejs
  • 【蓝牙协议栈】【BLE】低功耗蓝牙配对绑定过程分析(超详细)
  • MySQL表内容的增删查改
  • Java的三大特性之一——多态(完)
  • 算法-最短路径
  • 【软考---系统架构设计师】特殊的操作系统介绍
  • 大模型: 提示词工程(prompt engineering)
  • RabbitMQ的事务机制
  • 41 物体检测和目标检测数据集【李沐动手学深度学习v2课程笔记】
  • 软件包管理(rpm+yum)
  • 网关层针对各微服务动态修改Ribbon路由策略