当前位置: 首页 > 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>

参考链接:添加链接描述

相关文章:

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: …...

RPC浅析,加密数据解析

个人总结 其实就是HOOK注入wbsocket 链接创建服务端和客户端进行通信&#xff0c;直接调用js代码中的加密方法 将结果通过浏览器客户端传入服务端。一种比较好实用的一种技术 https://blog.csdn.net/qq_36759224/article/details/123082574 &#xff08;搬运记录下&#xff…...

光速论文能用吗 #媒体#知识分享#学习方法

光速论文是一个非常有效的论文写作、查重降重工具&#xff0c;它的使用非常简单方便&#xff0c;而且功能强大&#xff0c;是每个写作者必备的利器。 首先&#xff0c;光速论文具有强大的查重降重功能&#xff0c;能够快速检测论文中的抄袭部分&#xff0c;帮助作者避免不必要的…...

智慧工地解决方案,智慧工地项目管理系统源码,支持大屏端、PC端、手机端、平板端

智慧工地解决方案依托计算机技术、物联网、云计算、大数据、人工智能、VR&AR等技术相结合&#xff0c;为工程项目管理提供先进技术手段&#xff0c;构建工地现场智能监控和控制体系&#xff0c;弥补传统方法在监管中的缺陷&#xff0c;最线实现项目对人、机、料、法、环的全…...

【前端寻宝之路】学习和使用label标签

&#x1f308;个人主页: Aileen_0v0 &#x1f525;热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法|MySQL| ​&#x1f4ab;个人格言:“没有罗马,那就自己创造罗马~” #mermaid-svg-2nm9oQQVtSL8hDS1 {font-family:"trebuchet ms",verdana,arial,sans-serif;f…...

项目————网络聊天室

服务器 #include <myhead.h> typedef struct msg{char flag;char name[20];char cont[128]; }msg_t;typedef struct link{struct sockaddr_in cin;struct link* next; }link_t;void do_login(int sfd,msg_t msg,link_t *L,struct sockaddr_in cin){link_t* pL;if(sendto…...

【计算机网络】基本概念

基本概念 IP 地址端口号协议协议分层封装分用客户端服务器请求和响应两台主机之间的网络通信流程 IP 地址 概念&#xff1a;IP 地址主要是用于唯一标识网络主机、其他网络设备&#xff08;如路由器&#xff09;的网络地址。简单来说&#xff0c;IP地址用来唯一定位主机。格式&…...

Redis入门到实战-第七弹

Redis实战热身Sets篇 完整命令参考官网 官网地址 声明: 由于操作系统, 版本更新等原因, 文章所列内容不一定100%复现, 还要以官方信息为准 https://redis.io/Redis概述 Redis是一个开源的&#xff08;采用BSD许可证&#xff09;&#xff0c;用作数据库、缓存、消息代理和流…...

图像处理学习笔记(一)

本文主要介绍&#xff0c;以供读者能够理解该技术的定义、原理、应用。 &#x1f3ac;个人简介&#xff1a;一个全栈工程师的升级之路&#xff01; &#x1f4cb;个人专栏&#xff1a;ISP处理 &#x1f380;CSDN主页 发狂的小花 &#x1f304;人生秘诀&#xff1a;学习的本质就…...

duckdb学习-1

DuckDB is a fast in-process analytical database DuckDB supports a feature-rich SQL dialect complemented with deep integrations into client APIs 在notebook中使用duckdb 安装 pip install duckdb 示例代码: #> pip install jupysql #> pip install duckdb-en…...

GEE高阶案例——Landsat/Sentinel/MODIS影像进行缨帽变换一行代码实现

本教程的主要目的是利用eemont中的tasseledCap()的函数进行缨帽变换实现。 在 eemont 中,可使用扩展到 ee.Image 和 ee.ImageCollection 对象的 tasseledCap 方法计算缨帽亮度、绿度和湿度组件。只需从支持的平台加载图像,然后使用 tasseledCap 添加分量带即可。 代码: !p…...

数独游戏(c++题解)

题目描述 给出一个的表格&#xff0c;部分格子已经填好数。请填完所有空白格子&#xff0c;使得表格每一行、每一列、每个的九宫格&#xff0c;都恰好填满这9个数字。 输入格式 9行9列的方阵状态&#xff0c;0代表空格。 输出格式 输出完成后的方阵状态&#xff0c;每一个…...

【开发方案】Android 应用双卡搜网功能

一、功能简介 需求:开机自动开始搜网并显示网络列表 那么就不能将相关类做成单例,不能将subId、phoneId等卡相关的属性作为UI、服务的全局变量。 二、流程设计 NetworkSelectReceiver:监听开机广播,触发拉起搜网服务 NetworkOperatorService:搜网服务,完成后调起用户…...

图论基础|深度优先dfs、广度优先bfs

dfs 与 bfs 区别 提到深度优先搜索&#xff08;dfs&#xff09;&#xff0c;就不得不说和广度优先搜索&#xff08;bfs&#xff09;有什么区别 先来了解dfs的过程&#xff0c;很多录友可能对dfs&#xff08;深度优先搜索&#xff09;&#xff0c;bfs&#xff08;广度优先搜索…...

Python从入门到精通秘籍十七

一、Python的构造方法 在Python中&#xff0c;构造方法是一个特殊的方法&#xff0c;用于创建和初始化类的实例。构造方法的名称是__init__()&#xff0c;它在创建对象时自动调用。 下面是一个示例代码来详细解释Python的构造方法&#xff1a; class Person:def __init__(se…...

Java——抽象类和接口

目录 1.抽象类 1.概念: 2.语法 3.特性 2.接口 1.概念 2.语法 3.特性 1.抽象类 1.概念: 在面向对象的概念中&#xff0c;所有的对象都是通过类来描绘的&#xff0c;但是反过来&#xff0c;并不是所有的类都是用来描绘对象的&#xff0c;如果一个类中没有包含足够的…...

React—— props校验(非typescript校验类型)

非typescript环境下&#xff0c;当我们在封装组件的时候&#xff0c;接受props时传入的内容&#xff0c;需要做类型检测&#xff0c;那我们可以用props校验进行类型的检查。 props校验允许在创建组件的时候&#xff0c;就约定props的格式、类型等 实现步骤&#xff1a; 导入 …...

Go——map操作及原理

一.map介绍和使用 map是一种无序的基于key-value的数据结构&#xff0c;Go语言的map是引用类型&#xff0c;必须初始化才可以使用。 1. 定义 Go语言中&#xff0c;map类型语法如下&#xff1a; map[KeyType]ValueType KeyType表示键类型ValueType表示值类型 map类型的变量默认…...

网络安全实训Day9

写在前面 访问控制和防火墙桌面端安全检测与防御 网络安全实训-网络安全技术 网络安全概述 访问控制 定义&#xff1a;通过定义策略和规则来限制哪些流量能经过防火墙&#xff0c;哪些流量不能通过。本质是包过滤 可以匹配的元素 IP协议版本 源区域和目的区域 源IP地址和目…...

kubernetes实战(1)之虚拟机centos搭建k8s集群

一&#xff0c;环境准备 centos7系统&#xff0c;每个系统2c2g&#xff0c;40g&#xff0c;centos7下载地址&#xff1a;centos-7.9.2009-isos-x86_64安装包下载_开源镜像站-阿里云 # 每个节点分别设置对应主机名 hostnamectl set-hostname master hostnamectl set-hostname …...

一条命令部署OpenClaw?PPClaw的便利背后,先看清这些代价

先说结论PPClaw确实能大幅降低OpenClaw的初始部署门槛&#xff0c;尤其适合快速验证场景&#xff0c;但长期使用需考虑云端成本和控制权问题。工具的核心价值在于抽象了服务器运维和模型配置&#xff0c;但模型切换、自定义集成仍有一定学习成本&#xff0c;并非完全“零配置”…...

Qwen3-VL-8B-Instruct-GGUF效果展示:医疗报告图识别、工业零件缺陷描述、手写公式解析

Qwen3-VL-8B-Instruct-GGUF效果展示&#xff1a;医疗报告图识别、工业零件缺陷描述、手写公式解析 想象一下&#xff0c;你手头有一张复杂的医疗影像报告&#xff0c;上面布满了各种图表和标注&#xff1b;或者你面前是一个需要质检的工业零件&#xff0c;得找出上面细微的划痕…...

mysql事务提交慢的原因及对策_通过调整innodb_log_file_size优化

innodb_log_file_size过小会导致事务提交变慢&#xff0c;因其迫使InnoDB频繁checkpoint、刷脏页并阻塞日志复用&#xff0c;引发COMMIT延迟及锁等待&#xff1b;应按峰值1–2分钟写入量设置&#xff0c;需停库删除旧日志后重启生效。为什么 innodb_log_file_size 太小会让事务…...

Flink架构核心与资源优化全解析,Spring Boot SSE 流式输出,智能体的实时响应。

Flink 架构组件 Flink 的核心架构由多个协同工作的组件构成&#xff0c;确保分布式计算的高效性与容错性。 JobManager 负责协调作业执行&#xff0c;包括调度任务、管理检查点&#xff08;Checkpoint&#xff09;和故障恢复。JobManager 包含三个子组件&#xff1a; ResourceM…...

Kubernetes StatefulSet 完全指南,SOFA 架构--01--简介。

StatefulSet 的核心概念 StatefulSet 是 Kubernetes 中用于管理有状态应用的控制器&#xff0c;确保 Pod 具有稳定的网络标识和持久化存储。每个 Pod 拥有唯一的名称和持久化卷声明&#xff08;PVC&#xff09;&#xff0c;即使重启或重新调度也不会改变。 稳定网络标识的作用 …...

华硕笔记本散热难题:3步用G-Helper解决风扇失控与性能调优

华硕笔记本散热难题&#xff1a;3步用G-Helper解决风扇失控与性能调优 【免费下载链接】g-helper Lightweight, open-source control tool for ASUS laptops and ROG Ally. Manage performance modes, fans, GPU, battery, and RGB lighting across Zephyrus, Flow, TUF, Strix…...

Chord在科研视频处理中的应用:实验过程帧级语义标注与行为时序建模

Chord在科研视频处理中的应用&#xff1a;实验过程帧级语义标注与行为时序建模 1. 引言&#xff1a;科研视频分析的挑战与机遇 在科学研究领域&#xff0c;特别是生物学、心理学、医学和工程学等学科中&#xff0c;实验过程视频记录已成为不可或缺的研究手段。研究人员通过视…...

地理信息系统知识点03---空间数据模型

一、地理空间与空间抽象1. 地理空间地理空间是 GIS 的描述与分析对象&#xff0c;泛指地球表层空间及其相关的关联空间&#xff0c;既包含具有地理位置的实体、现象&#xff0c;也涵盖它们之间的相互作用与分布规律。从内涵上&#xff0c;地理空间具有区域性、多维性、随机性、…...

AcousticSense AI优化升级:如何提升识别准确率和响应速度

AcousticSense AI优化升级&#xff1a;如何提升识别准确率和响应速度 1. 从听到看&#xff1a;音频识别的新范式 传统音频识别技术往往受限于特征提取的局限性&#xff0c;而AcousticSense AI开创性地将声音转化为视觉信号进行处理。这套系统通过三个关键步骤实现音频理解&am…...

实测Nanbeige 4.1-3B WebUI:浅灰蓝波点背景+呼吸阴影效果惊艳

实测Nanbeige 4.1-3B WebUI&#xff1a;浅灰蓝波点背景呼吸阴影效果惊艳 1. 极简美学与功能设计的完美融合 第一次打开这个WebUI时&#xff0c;最直观的感受就是它完全颠覆了我对本地大模型界面的刻板印象。传统的部署方案往往只关注功能实现&#xff0c;界面设计几乎都是千篇…...