如何将两个微信小程序合并_微信小程序--如何在两个页面之间传值

news/2024/7/3 14:53:29

先看一下本周的部分的设计图

ce9048aa4f81?utm_campaign=maleskine...&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

在这里插入图片描述

ce9048aa4f81?utm_campaign=maleskine...&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

在这里插入图片描述

ce9048aa4f81?utm_campaign=maleskine...&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

在这里插入图片描述

页面设计并不太复杂,主要是产品类型那块点击的样式,其余的都不太复杂,没啥好说的。

这次主要是想记录一下不同页面下的传值

你看,在这个出发城市和目的地城市这两个搜索框点击了之后都跳转了页面,这也就意味着我们在这个工程项目里要新建两个文件夹。拿出发城市为例,原页面名字叫productList.wxml,点击了出发城市的搜索框之后跳转到出发城市的页面,名字叫departureCity.wxml。这是两个不同的文件夹的页面,这也意味着有两个js文件,那他们之间怎么传数据呢?我们需要把用户输入的城市名字传到前一个页面呀。

第一种方法:缓存

拿到用户的输入值,然后用wx.setStorageSync把值缓存下来

回到上一个页面,用wx.getStorageSync这个方法来拿到你需要的数据。

缓存真的是万金油,但是不推荐,显得笨重。肯定有更好的方法

第二种方法:getCurrentPages ()方法

ce9048aa4f81?utm_campaign=maleskine...&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

在这里插入图片描述

我们可以用getCurrentPages ()方法来获取当前页面的所有信息,如data数据

跳转后使用 let pages = getCurrentPages()获取当前页面栈的信息

得到并保存用户的输入值

let prevPage = pages[pages.length - 2]这是上一个页面的信息

prevPage.setData({[上一页data中的key]:[输入的值]});

这样我们就把数据保存到了上一页的data中

实例操作

departureCity.js中我们这样写:

returnAddress这个方法绑定了confirm事件,用户点击手机键盘的确定按钮就会跳转回去

returnAddress:function(e){

//本页即departureCity

let pages = getCurrentPages()

//上一页即productList

let prevPage = pages[pages.length - 2]

//得到用户的输入值

let inputValueA= e.detail.value

prevPage.setData({

//inputValue是productList.js里面data里面的定义的,我们把inputValueA的值赋给它

inputValue:inputValueA

})

// 返回上一级页面。即跳转到productList的页面

wx.navigateBack({

delta: 1

})

},

这样我们的productList页面就拿到了用户的输入值,这个值就储存在productList.js的data里,this.data.inputValue这个就是用户的输入值


http://www.niftyadmin.cn/n/3337884.html

相关文章

[分享]总结:VC小知识!-1

(1) 如何通过代码获得应用程序主窗口的 指针?主窗口的 指针保存在CWinThread::m_pMainWnd中,调用AfxGetMainWnd实现。AfxGetMainWnd() ->ShowWindow(SW_SHOWMAXMIZED)//使程序最大化. (2) 确定应用程序的路径Use GetModuleFi…

linux 错误信息 输出到管道,Linux管道只传到错误信息(stderr)——从一个小问题写起...

碰到问题在自己编写的一个小脚本中,碰到这个一个小问题:问题背景:在脚本中多次导出数据,为了不用重复输入密码,在运行时,使用read读取用户输入,将密码存入变量。将mysql的命令中使用该变量&…

java array_JAVA中数组是什么?

Java中数组是相同类型数据的有序集合。数组描述的是相同类型的若干个数据,按照一定的先后次序排列组合而成。其中,每一个数据称作一个元素,每个元素可以通过一个索引(下标)来访问它们。数组的三个基本特点:1. 长度是确定的。数组一…

用VC实现在TreeView中使用背景位图

一、引言:对于TreeView控件的背景位图的实现,目前介绍的文章比较少,有人虽然实现了,但是在点击TREE时,背景闪动比较厉害。本人在参照别人代码的基础上,把它总结一下,同时解决了这个背景闪烁的问…

目前NAXX所用到的一些BUFF和药水

一:药水buff(只罗列了个人认为有用的跟玩家buff不冲突的buff。如果还少什么请大家补充!) 泰坦合剂:使玩家的生命值上限提高1200点,持续2小时.制作需要:格罗姆之血(30) 石鳞鱼油(10) 黑莲花(1) 水晶瓶精练智慧合剂&…

java cache_比较Java中几种数据cache方式 | 学步园

现在很多网站一说到cache就想到memcached,memcached确实是非常优秀的系统,但是在某些场合,特别在不是分布式应用的场合,或者某些数据不需要分布式的访问,那它就未必是最佳的选择。下面比较3种cache方式,用测…

已经有windows再装linux,原有windows,现想再装linux,疑问?

hugogz 于 2009-02-27 17:05:55发表:安装时注意不要选错区就OK了hugogz 于 2009-02-27 17:05:52发表:安装时注意不要选错区就OK了三叶草 于 2009-02-27 12:41:01发表:你要是装LINUX的话,先把要装的空间留出来分为LINUX分区就可以装了li659258510 于 2009-02-27 03:1…

生产模块学习笔记(一)

原来的想法是能深入了解ERP中的一个模块,做得专一些,认真分析一下代码.现在看来这种想法是不可取的,ERP是个系统的工程,断章取义地弄一个模块会有一种瞎子摸象的感觉.在财务和物流模块了解一点后,轮到生产模块了.各个企业真正有个性的地方体现在生产,财务国家国家有统一的制度,…