js 监听问题求助 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
youngPacce
V2EX    前端开发

js 监听问题求助

  •  
  •   youngPacce 2024-06-17 10:40:22 +08:00 1266 次点击
    这是一个创建于 483 天前的主题,其中的信息可能已经有所发展或是发生改变。

    现在有两个块,结构如下:

    <div id = "outer" style = "width:50px;height:50px;"> <span id = "inner" style = "positon:absolute;buttom:0;right:0;width:5px;height:5px;"> lt;/span> </div> 

    如图: https://mjj.today/i/TXCM5H 这两个块都监听了mousedown,mousemove,mouseup

    我想实现的功能

    点击 outer 可以移动整个块,点击 inner 拖动可以控制 outer 块的宽高。

    现状

    如果我拖拽 inner 的话,outer 会在增加宽高的同时移动。

    尝试过

    增加一个状态控制 outer 不进行处理,但是无法实现两个功能同时存在。

    这种情况有什么好的处理办法吗?用的原生的 js 。

    7 条回复    2024-06-18 09:05:40 +08:00
    johnnyNg
        1
    johnnyNg  
       2024-06-17 10:47:06 +08:00
    mouse 事件里面有 eventtarget 吧,判断一下 target 是 outer 还是 inner
    johnnyNg
        2
    johnnyNg  
       2024-06-17 10:53:24 +08:00
    还有一种方案,在各个事件里面阻止一下事件冒泡
    youngPacce
        3
    youngPacce  
    OP
       2024-06-17 11:18:18 +08:00
    @johnnyNg 尝试过,但是 target 在移动的过程中貌似会冒泡传递出去,导致这个 target 最终不准确,还是用不了。我倒是没尝试过阻止事件冒泡,我去了解一下。
    zhtyytg
        4
    zhtyytg  
       2024-06-17 11:27:58 +08:00
    肯定要阻止事件冒泡的,前端常识
    yanyiming
        5
    yanyiming  
       2024-06-17 15:37:03 +08:00 via Android
    在 inner 的事件处理器中给事件对象增加一个属性,比如 fromInner: true ,因为事件对象是会传递到 outer 的,所以 outer 也能获取这个属性值。然后根据属性值判断逻辑即可。
    youngPacce
        6
    youngPacce  
    OP
       2024-06-17 15:52:55 +08:00
    @yanyiming j 具体怎么处理呢? e.target 还是 e.frominner? 另外我的 mousemove 和 mouseup 都是加在 ducoment 上的,似乎到了 mousemove 再判断 target 就不太好使了。
    youngPacce
        7
    youngPacce  
    OP
       2024-06-18 09:05:40 +08:00
    解决了,这里说一下我的解决方案,

    我是在 mousedown 之后才添加 mousemove,mouseup 事件。
    mouseup 之后就会移除掉 mousemove mouseup 事件。
    只需要在 inner 触发 mousedown 的时候阻止冒泡就行了。
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     5994 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 27ms UTC 01:42 PVG 09:42 LAX 18:42 JFK 21:42
    Do have faith in what you're doing.
    ubao snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86