微信小程序之页面传值

友情提醒:本文最后更新于 2020 天前,文中所描述的信息可能已发生改变,请谨慎使用。

前一段时间,公司接了一个项目,因为之前一直写H5,但是这次客户要做小程序,所以我也开始跳到小程序的坑里了,填坑之路艰辛而凄凉,所以在此记录一下小程序中的页面传值。

一. 跨页面传值

1 . 用 navigator标签传值或 wx.navigator, 比如
<navigator url="/page/component/news/detail?cms_id=15"></navigator>

这里将cms_id=15参数传入 detail 页面, 然后 detail 页面的 onload 方法内接收。

onLoad: function (options) {
  this.setData({
    cms_id: options.cms_id
  })
},

如果需要传多个参数, 用 & 链接即可

<navigator url="/page/component/news/detail?cms_id=15&cms_name=测试一下"></navigator>
onLoad: function (options) {
  this.setData({
    cms_id: options.cms_id,
    cms_name: options.cms_name,
  })
},
2. 写入本地, 跨页面再取出来 wx.setStorage/wx.getStorage等, 小程序中对写入本地数据 封装了很多方法, 各有侧重, 这里就不多说了

# 从本地缓存中异步获取指定 key 的内容
wx.getStorage({
  key: 'key',
  success (res) {
    console.log(res.data)
  }
})
# 从本地缓存中同步获取指定 key 的内容
try {
  var value = wx.getStorageSync('key')
  if (value) {
    // Do something with return value
  }
} catch (e) {
  // Do something when catch error
}

二. 页内传值

1. 设置 data-xxx 的方法来标识要传递的值

在bindtap定义的点击方法 delAddress : function(e) 中获取

var address_id = e.currentTarget.dataset.id;
2. 设置id的方法标识跳转后传递后的参数

在bindtap定义的点击方法 delAddress : function(e) 中获取

var address_id = e.currentTarget.id;
3. form表单和input输入框

bindSubmit: function(e) {
  var value = e.detail.value;
  var mobile = value.mobile;
  var captcha = value.captcha;
}

注:可能总结的并不是很全面,欢迎补充指正。

上一篇:MySQL中的配置参数interactive_timeout和wait_timeout

下一篇:Python面向对象编程之封装、继承与多态