Menu
小程序资讯
小程序资讯
微信小程序学习《二》:事件详解
时间:2016-10-17 21:01:00

一、什么是事件?

1.一种用户的行为

用户长按某一张图片,点击某个按钮,这就是用户的行为,也是事件

2.一种通讯方式

为什么说事件也是一种通讯方式呢?因为用户点击按钮的时候,这是发生在UI层的,我们的UI要把一些信息发送给我们的逻辑代码,因此也是一种通讯方式


二、事件的类别

1.点击事件tap

2.长按事件longtab

3.触摸事件

(1)touchstart 开始触摸

(2)touchend 结束触摸

(3)touchmove 移动触摸

(4)touchcancel取消触摸

这里就有个问题了,结束触摸和取消触摸有什么区别吗?

结束触摸可以理解为是主动的停止的触摸事件,比如我们正在移动一张图片,移动完成后就是结束触摸了,然后可能在移动的过程中,突然有事件来打断了触摸事件,比如电话来了,打断了你的触摸事件,这时候就是取消触摸了

4.其他的触摸事件 submit

每个控件都有自己的事件


三、事件冒泡

了解什么是冒泡事件?什么是非冒泡事件?我们可以通过一个例子来理解什么是冒泡事件。

1.首先我们先修改下启动界面,启动界面创建三个view组件,分别给他们对应的样式和绑定他们的点击事件,且布局是一层嵌套一层的

2.然后在index.wxss文件中写下他们对应的样式

3.在index.js文件中写对应的点击事件,在控制台输出对应的log

4.最后我们看下效果,仔细观察可以看到,我们点击界面3的时候,控制台输出了3行,分别是clickView1,clickView2,clickView3的点击事件,点击界面2的时候,控制台输出了clickView2和clickView1,这就说明了点击子view的时候,也会响应父view的事件,这就是冒泡事件了,相反的,点击子view,父view不会响应点击事件,这就是非冒泡事件了。

那么冒泡事件有哪些呢?

上面所提到的点击事件,长按事件,触摸事件都是冒泡事件,其余的都是非冒泡事件


四、事件的绑定

1.bind

上面的冒泡事件的例子就是使用bind的方式来绑定事件的

2.catch

那么catch绑定事件和bind的绑定事件有什么不同呢?我们通过修改上面的例子来说明,我们把view3的bindtap改为catchtap

然后我们看下运行的效果:

可以看到,我们使用catch的绑定事件后,点击界面3,是没有触发到父view的点击事件的

总结:使用bind的绑定事件,是可以触发冒泡事件的,就是可以触发父view的事件 
使用catch是不会触发冒泡事件


Demo的下载地址:Demo2.zip