《智能前端技术与实践》——第 2 章 前端开发基础 ——2.7 微信小程序开发——2.7.5 小程序的事件系统

简介: 《智能前端技术与实践》——第 2 章 前端开发基础 ——2.7 微信小程序开发——2.7.5 小程序的事件系统

2.7.5 小程序的事件系统


当我们在 wxml 文件中定义好相关组件后,需要为定义好的组件绑定对应的事件来响 应用户与页面的交互操作。绑定的事件可以将用户的行为反馈到逻辑层并进行处理,从而 完成视图层到逻辑层的通信。当用户触发事件时,就会执行逻辑层中对应的事件处理函数, 该函数会接收一个事件对象(event)并以它作为参数。该事件对象可以携带额外信息,如 id、dataset、touches 等。


在微信小程序中,事件可以分为冒泡和非冒泡两种类型。其中,冒泡事件是指当一个组件 上的事件被触发后,该事件会向父节点传递;非冒泡事件是指当一个组件上的事件被触发后, 该事件不会向父节点传递。


表 2-19 列出了几个常见的冒泡事件。除该表中的事件之外,如无特殊声明,其他组件 自定义事件(如 form 的 submit 事件、input 的 input 事件、scroll-view 的 scroll 事件等)是 非冒泡事件。


image.png


image.png


了解了小程序的事件类型后,我们看一下如何给对应的组件绑定事件。我们在组件的属性 中定义一个绑定事件的属性,并设置该属性的值,作为组件的属性,它以 bind 或 catch 开头, 并在其后面加上事件类型字符串。其中,以 bind 开头的事件绑定不会阻止冒泡事件向上冒泡, 以 catch 开头的事件绑定可以阻止冒泡事件向上冒泡。我们来看一个简单的案例,代码清单 2-61 即为 wxml 文件中的代码。


代码清单 2-61


<view class="container">
<button bindtap="clickMe" type="primary">单击</button>
</view>

代码清单 2-62 即为 js 文件中的代码。


代码清单 2-62

Page({
clickMe(event){
console.log(event)
}
})

我们在 index.wxml 页面中定义了一个按钮,指定其类型为 primary,并添加触摸事件,其 事件函数名称为 clickMe。在 index.js 文件中,我们定义了该函数的处理逻辑,即在控制台输 出事件对象 event 的相关内容,如图 2-49 所示。


image.png


图2-49 event对象的相关内容


一般情况下,我们可以将控制台显示的所有属性分为 3 种,包括基础事件对象属性 (BaseEvent)、自定义事件对象属性(CustomEvent,继承自 BaseEvent)和触摸事件对象属性 (TouchEvent,继承自 BaseEvent),分别如表 2-20、表 2-21、表 2-22 所示。


image.png
image.png



最后,解释常用的属性。


type 属性表示事件的类型,其值是一个字符串。图 2-49 中 type 属性的值为 tap,表示对应 的事件处理函数是一个 tap 类型的事件。


timeStamp 属性表示从页面打开到触发事件所经过的毫秒数,其值是一个整数。图 2-49 中 timeStamp 属性的值为 284806,表示从页面打开到触发事件所经历的时长为 284806 ms。


target 对象表示触发事件的源组件,其值是一个对象。从图 2-49 中我们可以知道,target 对象有 4 个属性,如表 2-23 所示。


image.png


currentTarget 属性表示事件绑定的当前组件,其值是一个对象。大多数情况下,绑定的组 件的属性、属性值与 target 属性、target 属性值相同,即在大多数情况下,事件绑定的组件和 触发事件的源组件是相同的。


touches 属性表示当前停留在屏幕上的触摸点,其值是一个数组。数组中的每个元素是一 个 Touch 对象。touches 属性分为 3 类,如表 2-24 所示。


image.png


detail 属性表示自定义事件所携带的数据,其值是一个对象。单击事件的 detail 带有的 x、 y 同 pageX、pageY 一样,都代表距离文档左上角的水平、垂直距离。



目录
打赏
0
0
0
0
309
分享
相关文章
陪练,代练,护航,代打小程序源码/前端UNIAPP-VUE2.0开发 后端Thinkphp6管理/具备家政服务的综合型平台
这款APP通过技术创新,将代练、家政、娱乐社交等场景融合,打造“全能型生活服务生态圈”。以代练为切入点,提供模块化代码支持快速搭建平台,结合智能匹配与技能审核机制,拓展家政服务和商业管理功能。技术架构具备高安全性和扩展性,支持多业务复用,如押金冻结、录屏监控等功能跨领域应用。商业模式多元,包括交易抽成、增值服务及广告联名,同时设计跨领域积分体系提升用户粘性,实现生态共生与B端赋能。
68 10
技术小白如何利用DeepSeek半小时开发微信小程序?
通过通义灵码的“AI程序员”功能,即使没有编程基础也能轻松创建小程序或网页。借助DeepSeek V3和R1满血版模型,用户只需用自然语言描述需求,就能自动生成代码并优化程序。例如,一个文科生仅通过描述需求就成功开发了一款记录日常活动的微信小程序。此外,通义灵码还提供智能问答模式,帮助用户解决开发中的各种问题,极大简化了开发流程,让普通人的开发体验更加顺畅。
882 11
技术小白如何利用DeepSeek半小时开发微信小程序?
前端工程化和传统前端开发的区别是什么?
前端工程化相比传统前端开发,在开发模式、代码组织与管理、构建与部署流程、团队协作、性能优化以及技术选型等方面都有了显著的改进和提升,能够更好地应对现代前端应用开发的复杂性和高要求。
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
99 5
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
微信小程序数据绑定与事件处理:打造动态交互体验
在上一篇中,我们学习了搭建微信小程序开发环境并创建“Hello World”页面。本文深入探讨数据绑定和事件处理机制,通过具体案例帮助你打造更具交互性的小程序。数据绑定使用双花括号`{{}}`语法,实现页面与逻辑层数据的动态关联;事件处理则通过`bind`或`catch`前缀响应用户操作。最后,通过一个简单的计数器案例,巩固所学知识。掌握这些核心技能,将助你开发更复杂的小程序。
解锁高效应用构建:Vuex与后端交互的前端状态同步策略,让数据流动如行云流水,紧跟前端开发的热点趋势
【8月更文挑战第27天】本文深入探讨了Vue框架下的前端状态管理库Vuex与后端服务交互时的状态同步策略。通过剖析Vuex的核心机制——状态(State)、变异(Mutation)、动作(Action)及模块(Module),文章展示了如何优雅地将后端数据加载并更新至前端状态中。特别地,借助示例代码解释了Action处理API调用、Mutation更新状态的过程,并介绍了如何通过模块化和命名空间提高状态管理的准确性和时效性。此外,还讨论了组件如何利用`mapState`和`mapActions`简化状态访问与操作的方法。遵循这些策略,开发者可以在构建复杂应用时显著提升性能与用户体验。
113 0
中后台前端开发问题之中后台前端开发中的复杂交互问题如何解决
中后台前端开发问题之中后台前端开发中的复杂交互问题如何解决
70 0
前端小白逆袭记:从零开始,如何快速掌握前端开发精髓?
本文从一个前端小白的视角,分享了快速掌握前端开发核心技能的逆袭之路。通过学习HTML、CSS和JavaScript,逐步接触前端框架如Bootstrap、Vue.js和React,克服挑战,最终实现从入门到精通的蜕变。
60 4
小程序的前端插件都有哪些?
【10月更文挑战第16天】小程序的前端插件都有哪些?
110 1
微信小程序地图定位的核心技术与实际应用详解
在移动互联网时代,微信小程序凭借其轻量化和普及性,成为室内地图导航的理想平台。本文探讨了微信小程序在室内定位领域的创新应用,包括蓝牙iBeacon定位、高精度地图构建及AI路径规划等核心技术,及其在购物中心、医院、机场火车站和景区等场景的应用,展示了其为用户带来的高效、智能的导航体验。
248 0

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等