1、使用navigator的url带参传值

(1)在pageA页面有一个固定的值要传递到pageB页面,比如说一个固定的值user_id要传递给B

<navigator url="../index/pageB?user_id='12345678'">index4</navigator>

注:?后面为你要传递的值

这样在pageB页面js的onload函数里面,使用setData方法可以获取到传递过来的值,并将它赋值给pageB页面初始数据
在pageB页面的data里面声明一个初始数据

data: {
user_id:''
},

然后在onload函数中进行操作,页面加载时获取

onLoad: function (options) {
this.setData({
user_id:options.user_id
})
console.log(this.data.user_id)
},

(2)在一般情况下我们要传多个值,与上面的差不多,只是多加了一个&,下面我代码示范

pageA

<navigator url="../index/pageB?user_id='12345678'&user_name='lhs'">index</navigator>

pageB

data: {
user_id:'',
user_name:''
},
onLoad: function (options) {
this.setData({
user_id:options.user_id,
user_name: options.user_name,
})
console.log(this.data.user_id)
console.log(this.data.user_name)
},

(3)当然也可以在js页面传值,比如使用wx.navigateTo、wx.redirectTo等,下面我让大家看看与navigator对应关系

从上面可以看出navigator的open-type="navigate"(不写默认值是navigate)等于wx.navigateTo

好了,我接着使用wx.navigateTo使用传值;首先在pageA绑定一个点击事件

<button catchtap="pageB">index</button>

在事件中写入参数,当然如果是传多个参数的话就要在后面加&

pageB: function () {
wx.navigateTo({
url: '../logs/logs?user_id=' + 520,
})
},

详细:

1、wx.navigateTo:保留当前页面,跳转到应用内的某个页面。但是不能跳到 tabbar 页面。使用 wx.navigateBack 可以返回到原页面。小程序中页面栈最多十层。(可带参)

2、wx.redirectTo:关闭当前页面,跳转到应用内的某个页面。但是不允许跳转到 tabbar 页面。(可带参)

3、wx.switchTab:跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面(不可带参)

4、wx.reLaunch:关闭所有页面,打开到应用内的某个页面(可带参)

5、wx.navigateBack :关闭当前页面,返回上一页面或多级页面。可通过 getCurrentPages 获取当前的页面栈,决定需要返回几层。(没有url属性,不可带参)

总结:

switchTab这种导航方式,不能带参,也就是说不能通过url进行传参,解决方法就是如果要跳转到tab页面,使用reLaunch方法

2、利用getCurrentPages进行页面传值

(1).getCurrentPages()获取当前页面栈。数组中第一个元素为首页,最后一个元素为当前页面。

pageA:dataFromB和dataFromC都是从pageB和pageC获取的,暂时没有数据

<text class='currentPage'>当前页面:[pageA.wxml]</text>
<view class='container'>
<text>{{name}}</text>
<text>{{dataFromB}}</text>
<text>{{dataFromC}}</text>
</view> <button type = "primary" catchtap='goToPageB'>跳转到pageB</button>

pageA的样式

page{
display: flex;
flex-direction: column;
align-items: center;
height: 100%;
width: 100%;
background: #fff;
} .currentPage{
width: 100%;
height: 80rpx;
padding-left: 150rpx;
background-color: red;
line-height: 80rpx;
color: #fff; }
.container{
width: 600rpx;
height: 300rpx;
background-color: red;
margin-top: 80rpx;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
margin-bottom: 80rpx;
color: #fff;
}

pagaA要初始化数据,绑定goTopageB跳转到pageB

data: {
name: '花泽香菜',
dataFromB: '',
dataFromC: ''
},
goToPageB: function () {
// 保留当前页面,跳转到应用内的某个页面。但是不能跳到 tabbar 页面。小程序中页面栈最多十层
wx.navigateTo({
url: '../pageB/index',
})
},

pageB:array[index]是传值给pageA的数据,这里绑定goToPageC函数跳到pageC

<text class='currentPage'>当前页面:[pageB.wxml]</text>
<view class='container'>
<!-- <text>{{name}}</text> -->
<picker bindchange="bindPickerChange" value="{{index}}" range="{{array}}">
<view class="picker">
国籍:{{array[index]}}
</view>
</picker>
</view> <button type = "primary" catchtap='goToPageC'>跳转到pageC</button>

pageB的样式

page {
display: flex;
flex-direction: column;
align-items: center;
height: 100%;
width: 100%;
background: #fff;
} .currentPage {
width: 100%;
height: 80rpx;
padding-left: 150rpx;
background-color: #0ff;
line-height: 80rpx;
} .container {
width: 600rpx;
height: 300rpx;
background-color: #0ff;
margin-top: 80rpx;
display: flex;
align-items: center;
justify-content: center;
margin-bottom: 80rpx;
}

初始化pageB数据,这里是通过getCurrentPages获取页面栈给pageA传值的

data: {
array: ['德国', '日本', '英国', '法国', '比利时'],
},
// 传值
bindPickerChange: function (e) {
let pages = getCurrentPages(); let currPage = null; //当前页面
let prevPage = null; //上一个页面 if (pages.length >= 2) {
currPage = pages[pages.length - 1]; //最后一个元素为当前页面。
prevPage = pages[pages.length - 2]; //上一个页面
console.log(currPage + "," + prevPage);
}
if (prevPage) {
//给pageA页面赋值
prevPage.setData({
dataFromB: '国籍:' + this.data.array[e.detail.value]
});
}
//给当前页面赋值
this.setData({
index: e.detail.value
})
},
goToPageC: function () {
wx.navigateTo({
url: '../pageC/index',
})
},

pageC:通过绑定goToPageA函数跳回pageA页面

<text class='currentPage'>当前页面:[pageC.wxml]</text>
<view class='container'>
<!-- <text>{{name}}</text> -->
<picker bindchange="bindPickerChange" value="{{index}}" range="{{array}}">
<view class="picker">
作品:{{array[index]}}
</view>
</picker>
</view> <button type = "primary" catchtap='goToPageA'>跳转到pageA</button>

pageC样式

page {
   display: flex;
flex-direction: column;
align-items: center;
height: 100%;
width: 100%;
background: #fff;
}
.currentPage {
width: 100%;
height: 80rpx;
padding-left: 150rpx;
background-color: pink;
line-height: 80rpx;
}
.container {
width: 600rpx;
height: 300rpx;
background-color: pink;
margin-top: 80rpx;
display: flex;
align-items: center;
justify-content: center;
margin-bottom: 80rpx;
}

初始化数据,这里是通过wx.navigateBack返回pageA,如果使用wx.navigateTo返回pageA是没有传值

/**
* 页面的初始数据
*/
data: {
array: ['恋爱循环', '大丈夫'],
},
bindPickerChange: function (e) {
let pages = getCurrentPages(); let currPage = null; //当前页面
let prevPage = null; //上一个页面 if (pages.length >= 2) {
currPage = pages[pages.length - 1]; //最后一个元素为当前页面。
prevPage = pages[pages.length - 3]; //pageA页面
console.log(currPage + "," + prevPage);
}
if (prevPage) {
//给上一个页面赋值
prevPage.setData({
dataFromC: '代表作品:' + this.data.array[e.detail.value]
});
}
//给当前页面赋值
this.setData({
index: e.detail.value
})
},
goToPageA: function () {
// 关闭当前页面,返回上一页面或多级页面。
wx.navigateBack({
delta:2
})
},

运行效果:

注意:

  • 不要尝试修改页面栈,会导致路由以及页面状态错误。
  • 不要在 App.onLaunch 的时候调用 getCurrentPages(),此时 page 还没有生成。
  • 小程序页面栈最多有十个,多了就不能使用wx.navigateTo跳转

(2)页面栈

从上图可知使用wx.navigateBack页面不断出栈,直到目标返回页;即pageA使用wx.navigateTo跳到pageB,pageB使用wx.navigateTo跳到pageC,pageC使用wx.navigateBack跳到pageA,而页面栈是一路出栈的直到返回pageA,这时页面栈就只有一个pageA

举个例子,pagaA查看页面栈的数量:

总数是1,而这个页面栈就是pageA了

3. globalData全局对象

在 app.js 中定义全局变量

globalData: {
userInfo: null,
globalName:"lhs"
}

在其他页面可以取到全局变量

let app = getApp();
console.log(app.globalData.globalName)

4、数据缓存

数据缓存,类似于cookie,localstorage,sessionstorage等本地缓存的方法,只不过微信小程序有它自己的本地缓存API。当然,为什么非要使用这种方法呢?

当然有第一二种方法不能用的情况,举个例子,同样要将页面A的内容传递给页面B,但是页面B和页面A没有父子页面关系,说简单一点,就是A页面和B页面没有跳转关系,但是B页面就是要从A页面拿数据,前面提到页面带参跳转就没有用了,如果页面层级太多,页面栈的方法也就没有,所以就要用到我们的第三种方法,数据缓存,将页面A的数据本地缓存,然后在B页面的onLoad函数中使用就行

(1)wx.setStorage(OBJECT)和wx.getStorage(OBJECT)(异步接口)

将数据存储在本地缓存中指定的 key 中。会覆盖掉原来该 key 对应的内容。除非用户主动删除或因存储空间原因被系统清理,否则数据都一直可用。单个 key 允许存储的最大数据长度为 1MB,所有数据存储上限为 10MB。

首先在页面A的onload中使用wx.setStorage将要B页面需要的值存储起来,如果需要存储多个值,可以封装成数组或者对象键值对的形式

data: {
info:{'name': '周杰伦',
'phone': '123456789',
'address': '台北'}
},
/**
* 生命周期函数--监听页面加载
*/
onLoad: function (options) {
var that = this
wx.setStorage({
key: 'information',
data: that.data.info,
success(res){//等同于success:function(res),es6的写法,es6在小程序中都可以使用,推荐使用
。。。。。。。
}
})
},

在B页面我们只需要使用wx.getStorage()就可以拿到你需要的值了

data: {
name:'',
phone:'',
address:''
}, /**
* 生命周期函数--监听页面加载
*/
onLoad: function (options) {
var that = this
wx.getStorage({
key: 'information',
success: function(res) {
console.log(res.data)
that.setData({
name: res.data.name,
phone: res.data.phone,
address: res.data.address
})
}
})
},

当然现在我们可以在A页面采取页面跳转跳到B页面看有没有获取到数据,其实也没有必要,答案当然是获取到了

注:这里还有一个同步 wx.setStorageSyncwx.getStorageSync,使用方法一样

 

(2).wx.clearStorage和wx.clearStorageSync(异步,同步清除缓存)

这种方法的弊端就在这儿,清除缓存,什么时候清除合理,都是值得思考的问题
我想一般就是在退出登录的时候执行吧,不能过早,也不能过晚,时机很重要

(3).wx.removeStorage(OBJECT)和wx.removeStorageSync(OBJECT)(异步,同步)

从本地缓存中异步移除指定 key
使用方法和存储数据一样,OK,不多做赘述

(4).wx.getStorageInfo(OBJECT)和wx.getStorageInfoSync(异步,同步)

wx.getStorageInfo异步获取当前storage的相关信息,比如说已经占用了多少存储空间

wx.getStorageInfo({
success: function(res) {
console.log(res.keys)//当前storage中所有的key
console.log(res.currentSize)//当前占用的空间大小, 单位kb
console.log(res.limitSize)//限制的空间大小,单位kb
}
})

wx.getStorageInfoSync()同步获取当前storage的相关信息

try {
const res = wx.getStorageInfoSync()
console.log(res.keys)
console.log(res.currentSize)
console.log(res.limitSize)
} catch (e) {
// Do something when catch error
}

看到这里大家应该注意到,结尾有Sync的为同步。

同异步区别:

1、同步方法会堵塞当前任务,直到同步方法处理返回。
2、异步方法不会塞当前任务。

微信小程序——详细讲解页面传值(多种方法)的更多相关文章

  1. Java Web项目,Android和微信小程序的初始页面配置

    Java Web项目 我们在Eclipse里开了Java Web项目之后,Run As Tomcat或者Apache服务器,本地运行,如果直接用http://localhost:8080访问项目,会发 ...

  2. (十二)微信小程序实现登陆页面+登陆逻辑

    微信小程序实现登陆页面 实现上面两个页面 第一个页面 <view> <!-- 上侧部分 --> <view class="top-view"> ...

  3. 完整微信小程序授权登录页面教程

    完整微信小程序授权登录页面教程 1.前言 微信官方对getUserInfo接口做了修改,授权窗口无法直接弹出,而取而代之是需要创建一个button,将其open-type属性绑定getUseInfo方 ...

  4. 微信小程序自动去除input空格的方法

    当用户输入账号或者密码的时候,可能会有输入空格的情况,但是实际需要是不能够有空格的,所以我们要做一个去除空格,并且适应所有input的name参数的方法,下面请看源码: wxml: <input ...

  5. 微信小程序详细图文教程-10分钟完成微信小程序开发部署发布

    很多朋友都认为微信小程序申请.部署.发布很难,需要很长时间. 实际上,微信和腾讯云同是腾讯产品,已经提供了10分钟(根据准备资源情况,已完成小程序申请认证)完成小程序开发.部署.发布的方式.当然,实现 ...

  6. 微信小程序开发 [02] 页面注册和基本组件

    1.页面注册 既然我们希望跳转到新的页面,那自然要新建页面相关的文件才行.在开篇已经讲过,一个小程序页面由四个文件组成,假如我们的页面名为welcome,那么这四个文件则是: welcome.js w ...

  7. 微信小程序之实现页面缩放式侧滑效果

    效果图: 实现原理:点击按钮,往需要动画的div中添加或移除拥有动画效果的class. 由于微信小程序中不能操作page这个根节点,所以,只有用一个div(view)来模仿page根节点. 1.结构 ...

  8. 微信小程序详解——页面之间的跳转方式【路由】和参数传递

    微信小程序拥有web网页和Application共同的特征,我们的页面都不是孤立存在的,而是通过和其他页面进行交互,来共同完成系统的功能.今天我们来研究小程序页面之间的跳转方式. 1.先导 在Andr ...

  9. 微信小程序从子页面退回父页面时的数据传递 wx.navigateBack()

    我们知道,在微信小程序中,从一个页面转到另一个页面,一般情况下可以通过navigate或redirect时候的url来携带参数,然后在目标页面的onLoad函数参数中获取这些url参数.例如: // ...

随机推荐

  1. [考试反思]0914csp-s模拟测试43:破绽

    T1会正解.爆int了,代码里一大堆long long但是有一个地方落了.-70分. 离考试结束还有19秒的时候发现手模样例爆负数了,没来得及改. T2没想.打暴力了.然而实际很好想...早读5分钟就 ...

  2. NOIP模拟26

    把题解沽了好久了,今天还是不想写,我们靠的B卷其实挺水的,但是我就是想吐槽一下!咋还带题目里面放题解的?题里一点题解的线索都没有,但是玄机竟然在题目里! 我也是醉了,T1就是一个贪心,题目说贪婪,T2 ...

  3. php微信卡券logo上传方法

    php微信卡券logo上传方法 <pre> $xiangmupath = $this->getxiangmupath(); $logo = $xiangmupath . '/imag ...

  4. centos中网卡的配置

    配置临时IP: ip a a 192.168.59.100/24 dev ens32 ifconfig ens32 192.168.59.100 up 在Linux最小安装之后,一般需要手动配置网络地 ...

  5. Linux命令实战(三)

    1.file检查并显示文件类型(determine file type) 一般用法就是file 后面接要查看的文件 可以一个或多个 [root@test test]# ll total 140 -rw ...

  6. 别翻了,这篇文章绝对让你深刻理解java类的加载以及ClassLoader源码分析【JVM篇二】

    目录 1.什么是类的加载(类初始化) 2.类的生命周期 3.接口的加载过程 4.解开开篇的面试题 5.理解首次主动使用 6.类加载器 7.关于命名空间 8.JVM类加载机制 9.双亲委派模型 10.C ...

  7. element 动态合并表格

    前言 element 官方的例子太简单了,不满足实际的需求 数据肯定是动态的,合并的行数,列数都是动态的,该如何知道每一行的合并数呢 需求 动态合并表格,数据来源于数据库 正文 一开始,我的数据源是单 ...

  8. spark集群搭建(三台虚拟机)——hadoop集群搭建(2)

    !!!该系列使用三台虚拟机搭建一个完整的spark集群,集群环境如下: virtualBox5.2.Ubuntu14.04.securecrt7.3.6_x64英文版(连接虚拟机) jdk1.7.0. ...

  9. pat 1035 Password(20 分)

    1035 Password(20 分) To prepare for PAT, the judge sometimes has to generate random passwords for the ...

  10. 关于 “'sqlite3' 不是内部或外部命令.....”问题

    学习django 按书上的  执行 manage.py dbshell 时, 报“'sqlite3' 不是内部或外部命令,也不是可运行的程序 或批处理文件.” 也就是指,环境变量中没有“sqlite3 ...