【微信小程序】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,
    });
  },
    
})

 

posted @ 2017-10-12 22:25  霍莉雪特  阅读(9207)  评论(0编辑  收藏  举报