《智能前端技术与实践》——第 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 一样,都代表距离文档左上角的水平、垂直距离。



相关文章
|
9月前
|
JSON 监控 前端开发
AMIS:百度开源的前端低代码神器,18.4k star 背后的开发效率提升利器
AMIS(前端低代码框架)是百度开源的低代码前端框架,基于纯 JSON 配置即可生成完整后台页面,包括表单、表格、图表、CRUD 列表,支持可视化拖拽编辑。,星标数已达 18.4k,百度内部已沉淀超过 5 万个页面,广泛应用于审核系统、数据管理后台、模型监控等落地场景
1607 0
|
8月前
|
人工智能 前端开发 JavaScript
前端工程化演进之路:从手工作坊到AI驱动的智能化开发
前端工程化演进之路:从手工作坊到AI驱动的智能化开发
963 18
前端工程化演进之路:从手工作坊到AI驱动的智能化开发
|
12月前
|
存储 消息中间件 前端开发
PHP后端与uni-app前端协同的校园圈子系统:校园社交场景的跨端开发实践
校园圈子系统校园论坛小程序采用uni-app前端框架,支持多端运行,结合PHP后端(如ThinkPHP/Laravel),实现用户认证、社交关系管理、动态发布与实时聊天功能。前端通过组件化开发和uni.request与后端交互,后端提供RESTful API处理业务逻辑并存储数据于MySQL。同时引入Redis缓存热点数据,RabbitMQ处理异步任务,优化系统性能。核心功能包括JWT身份验证、好友系统、WebSocket实时聊天及活动管理,确保高效稳定的用户体验。
643 4
PHP后端与uni-app前端协同的校园圈子系统:校园社交场景的跨端开发实践
|
自然语言处理 搜索推荐 小程序
微信公众号接口:解锁公众号开发的无限可能
微信公众号接口是微信官方提供的API,支持开发者通过编程与公众号交互,实现自动回复、消息管理、用户管理和数据分析等功能。本文深入探讨接口的定义、类型、优势及应用场景,如智能客服、内容分发、电商闭环等,并介绍开发流程和工具,帮助运营者提升用户体验和效率。未来,随着微信生态的发展,公众号接口将带来更多机遇,如小程序融合、AI应用等。
|
8月前
|
消息中间件 人工智能 Java
抖音微信爆款小游戏大全:免费休闲/竞技/益智/PHP+Java全筏开源开发
本文基于2025年最新行业数据,深入解析抖音/微信爆款小游戏的开发逻辑,重点讲解PHP+Java双引擎架构实战,涵盖技术选型、架构设计、性能优化与开源生态,提供完整开源工具链,助力开发者从理论到落地打造高留存、高并发的小游戏产品。
|
9月前
|
小程序 JavaScript API
uni-halo + 微信小程序开发实录:我的第一个作品诞生记
这篇文章介绍了使用uni-halo框架进行微信小程序开发的过程,包括选择该框架的原因、开发目标以及项目配置和部署的步骤。
493 0
uni-halo + 微信小程序开发实录:我的第一个作品诞生记
|
小程序 前端开发 Android开发
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
2308 29
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
4179 7
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
4790 1
|
人工智能 开发框架 机器人
AstrBot:轻松将大模型接入QQ、微信等消息平台,打造多功能AI聊天机器人的开发框架,附详细教程
AstrBot 是一个开源的多平台聊天机器人及开发框架,支持多种大语言模型和消息平台,具备多轮对话、语音转文字等功能。
8668 38
AstrBot:轻松将大模型接入QQ、微信等消息平台,打造多功能AI聊天机器人的开发框架,附详细教程

热门文章

最新文章