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
在这里插入图片描述
在这里插入图片描述
最后再改一下样式
在这里插入图片描述
打完收工:)

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

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值