微信小程序Page页面跳转(路由/返回)并传参

Posted 霍莉雪特

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了微信小程序Page页面跳转(路由/返回)并传参相关的知识,希望对你有一定的参考价值。

页面跳转的方法参考官方文档:

https://mp.weixin.qq.com/debug/wxadoc/dev/framework/app-service/route.html


 

问题:使用wx.navigator打开新页面时可以带参,但如果要wx.navegateBack回到上一级页面,该如何传参。

 

方法一:

将数据保存到app.js文件中。因为该文件中的属性是全局的,可以在任意Page页面中获取到app.js中的数据。

但是如果所有全局变量都放到app.js中,会导致该文件很臃肿。

 

方法二:

使用getCurrentPages(),找到上一级页面的Page实例,再通过setData来直接给上一级页面的data设置数据,实现传参!

Page({

  data: {
  },

  // 其他省略。。。

  // 输入框失去焦点的回调,添加条目
  addItem: function (event){
    console.log("添加条目!");
    wx.navigateBack();

    // 往上一级页面传参
    var pages = getCurrentPages();
    var currPage = pages[pages.length - 1]; // 当前页面
    var prevPage = pages[pages.length - 2]; // 上一级页面

    // 直接调用上一级页面Page对象,存储数据到上一级页面中
    var str = event.detail.value;
    prevPage.setData({
        \'addItemContent\': str,
    });
  },
    
})

 

以上是关于微信小程序Page页面跳转(路由/返回)并传参的主要内容,如果未能解决你的问题,请参考以下文章

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

微信小程序父组件使用子组件并传参

JS完成页面跳转并传参的方法|附加:循环遍历对象

Vue路由跳转并传值方式三种

Vue路由跳转并传值方式三种

微信小程序页面跳转url传参,对象、数据过长、特殊字符问题