draggable的el-dialog实现对话框标题可以选择

请看图

这个对话框使用了el-dialog并且draggable属性设置成了true,所以标题栏这里就可以拖动,现在用户想选中标题栏的文本进而复制。我看到这个需求头都大了。

我能想到的方案有三个:1. 取消draggable为true 2. 标题文案后面加一个复制按钮 3. 标题栏中文案那块区域不触发移动操作

最终我选择了第3个,也是最难的。

首先我要知道el-dialog怎么实现拖拽功能,那就去源码里找了呗。

最终找到了这里,我只需要给标题中文本这个dom添加一个mousedown事件,让其阻止事件向上传播就可以了,说干就干。

给el-dialog添加一个ref,如下

复制代码
<el-dialog ref="dialogRef"></el-dialog>

然后使用dialogRef找到标题文本对应的dom

dialogRef.value.$el.querySelector('.el-dialog__title')

可惜失败了,dialogRef.value.$el竟然是一个注释,我的天塌了:(

然后又尝试使用dialogRef访问组件树,均以失败告终,真是头大呀!!!

就在我放弃的时候,我的小脑袋瓜突然开窍了,不能从上到下,我就从下到上。我在el-dialog中找到一个节点,给它加上ref,然后通过它向上找到el-dialog的dom,再往下找el-dialog__title

最后再改一下样式

打完收工:)

如果对你有帮助,请帮忙点赞哦,嘻嘻:)

相关推荐
小雨下雨的雨4 分钟前
鸿蒙PC用Electron框架——Canvas蜡笔抖动效果实现技术深度解析
前端·javascript·华为·electron·鸿蒙系统
小雨下雨的雨29 分钟前
蜡笔小画家鸿蒙PC用Electron框架 - 儿童学画蜡笔画技术实现详解
前端·javascript·华为·electron·前端框架·交互·鸿蒙系统
小新11036 分钟前
vue 实战项目 天气查询
前端·javascript·vue.js
竹林81838 分钟前
用 wagmi v2 + viem 监听合约事件踩坑实录:从轮询到实时推送,我终于搞懂了
javascript
ai_coder_ai44 分钟前
如何在自动化脚本中实现定时操作?
java·前端·javascript
如烟花的信页1 小时前
易盾滑块逆向分析
javascript·爬虫·python·js逆向
努力早日退休1 小时前
一个 9999px 引发的跨平台血案:小程序离屏隐藏元素的滚动兼容性问题
前端·javascript
Darling噜啦啦1 小时前
正则表达式实战指南:从手机号验证到模板引擎,5 个案例彻底搞懂 RegExp
javascript·面试
sugar__salt1 小时前
JS正则表达式与字符串高阶实战精讲
开发语言·javascript·正则表达式
HjhIron1 小时前
从手机号校验到模板引擎:正则表达式的实战之旅
javascript