微信小程序踩坑——bind事件与catch事件区别

简介

  • 小程序中的事件分为冒泡事件非冒泡事件两类。(一般默认是可冒泡的)
  • bind绑定的事件不会阻止冒泡事件向上冒泡catch绑定的事件可以阻止冒泡事件向上冒泡(下面以tap点击事件为例来讲解二者区别)
       例:bindtap和catchtap事件都是当用户点击该组件的时候会执行该页面对应的Page中找到相应的事件处理函数,但是不同的是用bindtap不会阻止冒泡事件向上冒泡,catchtap会阻止冒泡事件向上冒泡(下面的实例会让你对二者有更清晰直观的认识)

实例

wxml:三层view从里到外嵌套

<view id="outside"  bindtap="outsideTap">

         outside view
         
    <view id="middle" bindtap="middleTap">
    
         middle view
 
       <view id="inside" bindtap="insideTap">
 
        inside view
 
       </view>
 
   </view>
 
</view>

js:事件处理函数


outsideTap:function(){
 
     console.log("触发了外部事件")
 
},
 middleTap: function () {
 
     console.log("触发了中部事件")
 
}, 
insideTap: function () {
  
     console.log("触发了内部事件")
 
}

实例解析:

  • 三个view均绑定bindtap事件
    • 点击outside view打印 “触发了外部事件”;
      点击middle view打印 “触发了中部事件” 和 “触发了外部事件”;
      点击inside view打印 “触发了内部事件” 和 “触发了中部事件” 和 “触发了外部事件” ;
  • 若将中部的midele view的bindtap事件改为catchtap事件
    • 点击middle view打印 “触发了中部事件” (catchtap阻止了继续向上冒泡触发outsideTap事件);
      点击inside view打印 “触发了内部事件” 和 “触发了中部事件” (catchtap阻止了继续向上冒泡触发outsideTap事件) ;
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值