赞
踩
一个应用仅仅只有界面展示是不够的,还需要和用户做交互,例如:响应用户的点击、获取用户输入的值等等,在小程序里边,我们就通过编写 JS
脚本文件来处理用户的操作
小程序中绑定事件与在网页开发中绑定事件几乎一致,只不过在小程序不能通过 on
的方式绑定事件,也没有 click
等事件,小程序中绑定事件使用 bind
方法,click
事件也需要使用 tap
事件来进行代替,绑定事件的方式有两种:
第一种方式:bind:事件名
,bind 后面需要跟上冒号,冒号后面跟上事件名
<button bind:tap="handler">按钮</button>
第二种方式:bind事件名
,bind 后面直接跟上事件名
<button bindtap="handler">按钮</button>
事件处理函数需要写到 .js
文件中,在 .js
文件中需要调用小程序提供的 Page
方法来注册小程序的页面,我们可以直接在 Page
方法中创建事件处理函数。例如:
// pages/home/home.js
Page({
// 页面的初始数据
data: {},
// 事件处理程序
handler () {
console.log('我被执行啦~~~')
}
// 其他 coding...
})
当组件触发事件时,绑定的事件的处理函数会收到一个事件对象,用来记录事件发生时的相关信息。在触发事件时,事件处理程序会主动的给我们传入一个参数 —— event
(事件对象)
// pages/home/home.js
Page({
// 页面的初始数据
data: {},
// 事件处理程序
handler (event) {
// console.log('我被触发了~~~')
console.log(event)
}
// 其他 coding...
})
事件分为冒泡事件和非冒泡事件:
使用 bind
绑定的事件,会触发事件冒泡,如果想阻止事件冒泡,可以使用 catch
来绑定事件。
<view bindtap="parentHandler">
<!-- 使用 bind 绑定的事件,会产生事件冒泡 -->
<!-- <button bindtap="handler">按钮</button> -->
<!-- 使用 catcht 绑定的事件,会阻止事件冒泡 -->
<button catchtap="handler">按钮</button>
</view>
Page({
// 页面的初始数据
data: {},
// 事件处理程序
handler (event) {
console.log('我是子绑定的事件 ~~~')
},
parentHandler () {
console.log('我是父绑定的事件 ~~~')
}
// 其他 coding...
})
WXML
中冒泡事件列表如下表:
类型 | 触发条件 |
---|---|
touchstart | 手指触摸动作开始 |
touchmove | 手指触摸后移动 |
touchcancel | 手指触摸动作被打断,如来电提醒,弹窗 |
touchend | 手指触摸动作结束 |
tap | 手指触摸后马上离开 |
longpress | 手指触摸后,超过350ms再离开,如果指定了事件回调函数并触发了这个事件,tap事件将不被触发 |
longtap | 手指触摸后,超过350ms再离开(推荐使用 longpress 事件代替) |
transitionend | 会在 WXSS transition 或 wx.createAnimation 动画结束后触发 |
animationstart | 会在一个 WXSS animation 动画开始时触发 |
animationiteration | 会在一个 WXSS animation 一次迭代结束时触发 |
animationend | 会在一个 WXSS animation 动画完成时触发 |
touchforcechange | 在支持 3D Touch 的 iPhone 设备,重按时会触发 |
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/羊村懒王/article/detail/448897
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。