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

最后再改一下样式

打完收工:)

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

相关推荐
Jing_Rainbow21 小时前
【React-10/Lesson94(2026-01-04)】React 性能优化专题:useMemo & useCallback 深度解析🚀
前端·javascript·react.js
白中白1213821 小时前
Vue系列-3
前端·javascript·vue.js
无巧不成书021821 小时前
React Native 深度解析:跨平台移动开发框架
javascript·react native·react.js·华为·开源·harmonyos
奋斗吧程序媛1 天前
vue3初体验(1)
前端·javascript·vue.js
资深web全栈开发1 天前
设计模式之桥接模式 (Bridge Pattern)
javascript·设计模式·桥接模式
UIUV1 天前
语义化搜索学习笔记(结合代码实战)
javascript·后端·node.js
2301_796512521 天前
【精通篇】打造React Native鸿蒙跨平台开发高级复合组件库开发系列:订单步骤条实践
javascript·react native·react.js·ecmascript·harmonyos
程序员酥皮蛋1 天前
react 01 初学react
前端·javascript·react.js
程序员林北北1 天前
【前端进阶之旅】3 道前端超难面试题深度解析(2026 版)|附完整代码 + 实战场景
前端·javascript·css3·html5
全马必破三1 天前
Vue 和 React 的区别
前端·vue.js·react.js