微信小程序 返回上一页并传参

     itemClick: function(e) {
          let pages = getCurrentPages();
          let prevPage = pages[pages.length - 2];
          prevPage.setData({
               message: e.currentTarget.dataset.msg,
          })
          wx.navigateBack({
               delta: 1,
          })
     },
  • getCurrentPages() 函数用于获取当前页面栈的实例,以数组形式按栈的顺序给出
  • pages[pages.length - 2] 是上一页,-1是当前页
  • 然后直接调用上一页的setData方法
  • message 是上一页定义的变量,e.currentTarget.dataset.msg为当前页要传的数据
  • 然后调用wx.navigateBack返回,delta表示返回的页数,如果delta大于现有页面数,则返回到首页。

微信小程序 关闭当前页面


微信小程序中,可以通过以下步骤实现跳转到 TabBar 页面并传参: 1. 在非 TabBar 页面的JS文件中,可以使用`wx.navigateTo`方法跳转到一个中间页面,并传递参数: ```javascript jumpToTabBar: function() { const queryString = 'param1=value1&param2=value2'; // 构建queryString const url = '/pages/middle/middle?queryString=' + encodeURIComponent(queryString); // 拼接URL并进行编码 wx.navigateTo({ url: url }); } ``` 2. 创建一个中间页面(middle),用于接收参数,并在该页面的JS文件中获取参数并跳转到TabBar页面: ```javascript onLoad: function(options) { const queryString = options.queryString; // 获取queryString const params = this.parseQueryString(queryString); // 解析queryString // 使用解析后的参数进行其他操作 console.log(params.param1); // 输出'value1' console.log(params.param2); // 输出'value2' // 跳转到TabBar页面 wx.switchTab({ url: '/pages/tabBar/index/index' }); }, parseQueryString: function(queryString) { const params = {}; const paramStrs = queryString.split('&'); for (let i = 0; i < paramStrs.length; i++) { const param = paramStrs[i].split('='); const key = decodeURIComponent(param[0]); const value = decodeURIComponent(param[1]); params[key] = value; } return params; } ``` 在上述代码中,`jumpToTabBar`方法中构建了带有queryString的URL,并通过`wx.navigateTo`跳转到中间页面。在中间页面的`onLoad`生命周期方法中,通过`options`参数获取到URL中的queryString,并通过`parseQueryString`方法解析出参数。然后可以使用解析后的参数进行其他操作。最后,使用`wx.switchTab`方法跳转到TabBar页面。 需要注意的是,由于URL长度限制和安全性考虑,queryString的长度和内容有一定限制。如果需要传递较长或敏感数据,建议使用其他方式,如通过接口获取数据。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yechaoa

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值