微信小程序-传递多个参数与事件处理

本文详细介绍了微信小程序中事件的定义与分类,包括冒泡与非冒泡事件的使用场景,以及参数传递的多种方式,如通过navigator跳转URL传递字符串、数组,和在wxml中使用data属性传递数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

开发过程中经常会遇到从一个页面携带数据到另一个页面的情况,所以需要知道以下信息,什么是事件?有哪些传递方式?如果传递数组呢?如果传递对象呢?

一、事件

什么是事件

  • 事件是视图层到逻辑层的通讯方式
  • 事件可以将用户的行为反馈到逻辑层进行处理
  • 事件可以绑定在组件上,当达到触发事件,就会执行逻辑层对应的事件处理函数
  • 事件对象可以携带额外信息,如id, dataset, touches

事件处理的使用

通过在wxml中设置bindtap、catchtap等,在js中写对应的实现方法(不过这种方式目前有个缺点,点击的时候没有点击效果),使用方法如下

以下摘自微信小程序官方教程,在wxml中绑定一个事件

<view id="tapTest" data-hi="WeChat" bindtap="tapName"> Click me! </view>

然后在对应的js中写出事件的具体实现

 
  1. Page({

  2. tapName: function(event) {

  3. console.log(event)

  4. }

  5. })

事件分类
事件分为冒泡事件和非冒泡事件

  1. 冒泡事件:当一个组件上的事件被触发后,该事件会向父节点传递
  2. 非冒泡事件:当一个组件上的事件被触发后,该事件不会向父节点传递

一般使用场景中,例如一个列表的item中有多个点击事件需要处理,就可以使用catchtap阻止向上冒泡

二、参数传递

参数传递有两种方式

  1. 在wxml中使用navigator跳转url传递参数
  2. 在wxml中绑定事件后,通过data-hi="参数"的方式传递

(1)navigator跳转url传递字符串参数

代码如下,将要传递到另一个页面的字符串testId的值赋值到url中

 
  1. <navigator class="test-item" url="../../pages/test/test?testId={{testData.testId}}">

  2. ...

  3. </navigator>

在js页面中onLoad方法中接收

 
  1. Page({

  2. onLoad: function(options) {

  3. var testId = options.testId

  4. console.log(testId)

  5. }

  6. })

(2)navigator跳转url传递数组
如果一个页面要将一个数组,如相册列表传递到另一个页面

 
  1. <navigator class="test-item" url="../../pages/test/test?albumList={{testData.albumList}}">

  2. ...

  3. </navigator>

传递到js后从options中得到的是个字符串,每个图片的url通过','分隔,所以此时还需要对其进行处理,重新组装为数组

 
  1. Page({

  2. data: {

  3. // 相册列表数据

  4. albumList: [],

  5. },

  6. onLoad: function (options) {

  7. var that = this;

  8.  
  9. that.setData({

  10. albumList: options.albumList.split(",")

  11. });

  12. }

  13. })

(3)wxml中配置data-testid传递字符串

这种方式一般是在wxml中绑定事件,同时设置需要传递的数据,如果需要传递多个,可以写多个data-[参数]的方式进行传递

 
  1. <view bindtap="clickMe" data-testId="{{testId}}">

  2. ...

  3. </view>

在js页面中自定义方法clickMe中接收

 
  1. Page({

  2. clickMe: function(event) {

  3. var testId = event.currentTarget.dataset.testid;

  4. wx.navigateTo({

  5. url: '../../pages/test/test'

  6. })

  7. }

  8. })

注意:通过wxml设置data-[参数名]传递参数,[参数名]只能是小写,不能有大写

(4)wxml中配置data-albumlist传递数组

其实原理同上,上代码

 
  1. <view bindtap="clickMe" data-albumlist={{testData.albumList}}">

  2. ...

  3. </view>

在js页面中自定义方法clickMe中接收

 
  1. Page({

  2. clickMe: function(event) {

  3. var albumList = event.currentTarget.dataset.albumlist.split(",");

  4. wx.navigateTo({

  5. url: '../../pages/test/test'

  6. })

  7. }

  8. })

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值