微信小程序的事件机制

作者: 水山一村 | 来源:发表于2017-02-17 10:57 被阅读3739次

在微信小程序中,可以看到同为点击事件,有的是bindtap而有的是catchtap,那么这两者有什么区别呢?为了进一步了解微信小程序的事件机制,在原DEMO的基础上增加了一个简单的页面。效果如下。

Paste_Image.png

红黄绿分别代表三个view。 红是最外层的, 黄绿依次为中底层。 每一层view对应着一个点击事件。(outtap,midtap,innertap)。

Page({
  outtap(event){
     console.log("out:"+event);
  },
   midtap(event){
    console.log("mid:"+event)
  },
   innertap(event){
    console.log("innertap:"+event)
  }
})

首先先把所有的事件都改为bindtap。分别点击inner层,middle层,out层。再看看日志上打印出来的数据。

<view id="out" class="out" bindtap="outtap">
                out
 <view id="middle" class="middle" catchtap="midtap">
                 middle
    <view id="inner" class="inner" bindtap="innertap">
                    inner
    </view>
 </view>
</view>
点击innertap.png 点击midtap.png 点击toptap.png

可以看到,当为view的点击时间为bindtap的时候, 点击最底层的innerview的时候,除了触发innertap的点击方法之外,事件还会往上进行传递,依次触发midtap和outtap方法。

然后我们把middle的bindtap改成catchtap,再分别点击三个视图层。(顺序 inner middle out)

点击innertap.png 点击midtap.png 点击toptap.png

可以看到,当mid层使用了catchtap后,事件执行到mid层之后,便不会再往上进行传递。

从上面的截出来的图片中, 我们可以看到点击了控件之后,返回的是一个Object对象,那么这个对象里面包含什么信息呢。查看官方文档。

Paste_Image.png

其中type为事件类型,timeStamp为事件生成的时间戳,target为触发事件的组件的一些属性值集合,currentTarget当前组件的一些属性值集合,touches为触摸事件,包含的信息为触摸点信息的数组,detail为额外的信息集合。

以下为事件的一些详细信息。
Paste_Image.png Paste_Image.png Paste_Image.png

从官方的文档中,我们可以发现,事件分为两种,一种是冒泡事件,另一种是非冒泡事件。
a.冒泡事件:当一个组件上的事件被触发后,该事件会向父节点传递
b.非冒泡事件:当一个组件上的事件被出发后,该事件不会向父节点传递。

显然bindtap属于冒泡事件,catchtap属于非冒泡事件。
除了bindtap之外,wxml的其他冒泡事件还有以下事件。

冒泡事件列表.png

注:除上表之外的其他组件自定义事件都是非冒泡事件,如<form/>的submit事件,<input/>的input事件,<scroll-view/>的scroll事件。

相关文章

网友评论

  • 守星的犬:首先先把所有的事件都改为bindtap。分别点击inner层,middle层,out层。再看看日志上打印出来的数据。

    <view id="out" class="out" bindtap="outtap">
    out
    <view id="middle" class="middle" catchtap="midtap">
    middle
    <view id="inner" class="inner" bindtap="innertap">
    inner
    </view>
    </view>
    </view>

    -----
    <view id="middle" class="middle" catchtap="midtap">
    代码这里写错了吧,应该是bindtap
  • manajay:如何 代码触发 bindtap
    LinDaiDai_霖呆呆:比如使用一个button来触发:
    <button bindtap='doSome'>点击</button>
  • 知晓程序:你好!我们是爱范儿旗下专注于小程序生态的公众号知晓程序(微信号 zxcx0101)。我们很赞赏你的文章,希望能获得转载授权。授权后,你的文章将会在知晓程序社区(minapp.com)、爱范儿、AppSo 等渠道发布。此外,由于第三方同步抓取功能,您的内容也可能会被同步发表到今日头条、搜狐、网易号等,我们会注明来源和作者姓名。

    非常感谢~~~

本文标题:微信小程序的事件机制

本文链接:https://www.haomeiwen.com/subject/ukmkwttx.html