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

最后再改一下样式

打完收工:)

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

相关推荐
午安~婉6 分钟前
构图跟拍相关
前端·javascript·拍照·虚拟列表
前端程序猿i17 分钟前
流式输出场景下的「双区域渲染」:让第三方 DOM 操作在 Vue 响应式更新中存活
前端·javascript·vue.js
css趣多多20 分钟前
setup() 函数与语法糖
前端·javascript·vue.js
前端程序猿i27 分钟前
第 3 篇:消息气泡组件 —— 远比你想的复杂
开发语言·前端·javascript·vue.js
墨染青竹梦悠然34 分钟前
基于SpringBoot + vue的农产品销售系统(华夏鲜仓)
vue.js·spring boot·python·django·毕业设计·毕设
爱上妖精的尾巴36 分钟前
8-7 WPS JS宏 正则表达式 元字符应用-提取连续数字
javascript·wps·jsa
JasonSJX1 小时前
海海软件正式发布全新 DRM-X官网 Next.js 重构、多语言升级与 SEO 优化,助力全球数字版权保护
开发语言·javascript·安全·重构·视频防录屏·开源drm·加密保护课程
wulijuan8886661 小时前
Vue 组件的通信方式有哪些?
前端·javascript·vue.js
k09331 小时前
vue中view-design的校验及各种坑
前端·vue.js·view design
Kyl2n1 小时前
【密码口令保存小工具】
javascript·css·css3