外部容器的拖拽事件如何不触发内部组件的点击事件

本文介绍了一种解决外部容器拖拽时内部组件点击事件被触发的难题。作者通过设置一个变量来判断是否处于拖拽状态,若在拖拽中,则避免触发内部组件的点击事件。详细实现思路涉及在拖拽过程中调整内部组件样式,以确保拖拽操作的正常进行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

心路

这个问题困扰了我实在很多天,百度无果,问了ChatGpt和claude都无果,也问过copilot chat。
一个都不能给出解决方案,最终想到了一个绝妙的方法解决了这个问题,希望是社区的第一个解决方案吧。

实现思路

主要是用一个变量来标识正处在拖拽状态,如果正在拖拽则将内部组件设置样式pointer-events: none
因为我使用了vue-draggable-resizable插件作为容器,所以就基于此基础上来做讨论。(其他情况的实现思路也一样)

代码实现

<vue-draggable-resizable
  @dragging="isDragging = true"
  @dragstop="isDragging = false"
>
  <component
    :class="{ 'is-disabled': isDragging }"
    is="c"
  />
</vue-draggable-resizable>
.is-disabled {
  pointer-events: none;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值