页面url带参数_微信小程序云开发教程微信小程序的JS高级页面间数据传递

  同学们大家好,我是小伊同学,上一节课我们讲解了全局数据的读写方法,那么在页面间同样需要数据交互,今天我们就来学习这部分内容。

  在微信小程序中,我们常常需要将数据在页面之间进行传递,比如用户的身份信息,在不同页面的接口中都需要这个参数,服务端通过这个参数来判断是哪个用户请求了服务。因此,数据在页面之间的传递在小程序开发中也是必不可少的。

56cd3de83669287cacde03a576339d82.png

  页面间数据传递主要有两种方式,第一种,通过页面跳转过程中携带参数,另一种方式是将数据保存在全局数据中,每个页面再从全局数据中读取。在本小程序中,我们主要使用了第二种,因此我们将讲解第二种方式,对于第一种同学们可以通过微信开发者文档进行学习。

d0c18e2864581f48e6dea7c420640b1f.png

  具体来说,我们可以通过URL传递参数。在原页面中,js文件中调用API进行跳转时在URL路径结尾后带参数。参数与路径之间使用 ? 分隔,参数键与参数值用 = 相连,不同参数用 & 分隔;如 "path?key=value&key2=value2" 。

  在打开的新页面中,js文件中onLoad函数接收参数中含有传递过来的数据。例如这里的示例,我们已经学过redirectTo是页面跳转的api,当我们执行后,在新页面就可以收到id变量,由于字符串可以拼接,我们可以在左边写成id=然后引号结束加号加上变量值。

67822cc361a4299a4afd0f3a9e17f54c.png

  其次,可以通过页面间事件通信通道(EventChannel)传递参数

在原页面中,js文件中调用API进行跳转时在success回调函数中向被打开页面传送数据。在打开的新页面中,js文件中onLoad函数持续监听事件获取页面传递参数。同样是传递id参数,我们分别拷贝使用这两段代码打开事件通信通道即可。

a4ba61eaf64e7b9833bc68299e7247a7.png

  下面我们来比较一下这几种方式。URL传递参数,只能从在A页面打开B页面时,从A页面向B页面传递参数。事件通信通道(EventChannel)传递参数,在A页面打开B页面时,可以从A页面向B页面传递参数,也可以同时从B页面向A页面传递参数(我们刚才只介绍了前者,后者给大家作为作业自学)。

  这两种方式通常用于传递简单数据,如标志信息、id信息和字符串等,使用时需要依赖路由API。而全局数据交互:不介意页面的打开顺序,通常用于传递重要共享数据,该数据往往在多个页面都需要而不仅仅限于两个页面之间,使用时需要使用getApp()。

  日拱一卒,功不唐捐。涓流所积,终成沧海。

想看视频版?

关注公号“微程序学堂”,我们的视频教程即将上线

如果你自己写了好文章想投稿

请联系我们

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/538099.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

软件测试员对英语,软件测试工程师英语面试题

以下是软件测试工程师部分英语面试中的参考回答,仅提参考:Interview English:一,Why are you interested in working for our company?1。Because your company has a good sales record.2。Because your operations are global,…

OpenGL——二维几何变换

平移、旋转、缩放的实现 #include<iostream> #include <math.h> #include<Windows.h> #include <GL/glut.h>using namespace std;GLsizei winWidth 600, winHeight 600;GLfloat xwcMin 0.0, xwcMax 225.0; GLfloat ywcMin 0.0, ywcMax 225.0;cla…

在Eclipse 中打开当前文件夹

原文连接&#xff1a;https://www.cnblogs.com/panie2015/p/5985053.html ------------------------------------------------------------------------ 最近试过好多次&#xff0c;安装插件来 在Eclipse 中打开当前文件所在文件夹&#xff0c;结果总是不甚如意。 烦躁了&…

清华大学计算机系主任应明生,清华大学计算机科学与技术系导师简介:应明生...

对考生而言&#xff0c;充分了解高校、专业以及师资情况是一项最基础、最关键的工作。以下是中公考研小编为大家整理的“清华大学计算机科学与技术系导师简介&#xff1a;应明生”的相关信息&#xff0c;希望对同学们有所帮助。姓名&#xff1a;应明生职称&#xff1a;教授邮件…

在VS2013平台下如何快速解决c++代码内存泄漏问题

在学习FPS3000人脸关键点定位算法时&#xff0c;发现github上的源码&#xff0c;存在大量的内存泄漏问题&#xff0c;在训练的时发现内存一直在增长&#xff0c;测试的时候也存在内存无法彻底释放的问题。 一直以为是存放模型参数vector<class>结构的问题&#xff0c; 采…

python请简述构造函数和析构函数的作用_python – 构造函数和析构函数如何工作?...

我正在尝试理解这段代码&#xff1a;class Person:Represents a person population 0def __init__(self,name)://some statements and population 1def __del__(self)://some statements and population - 1def sayHi(self):grettings from personprint Hi My name is %s % s…

服务器应用日志清理,Linux下Tomcat日志定期清理

服务器上的tomcat的catalina.out文件越来越大&#xff0c;查看起来很不方便&#xff0c;以前每次都是想起来的时候手工清理一下(cat /dev/null > catalina.out)&#xff0c;后来发现了logratate这个工具&#xff0c;Ubuntu下的mysql,nginx好像也是用的这个工具还定期整理log…

dubbo简易监控中心安装

dubbo简易监控中心也是dubbo服务应用。 为什么叫“简易”&#xff1f;这是阿里巴巴定义的&#xff0c;意思是功能不多但够用&#xff0c;可以自己扩展。 1、下载dubbo源码&#xff0c;要与使用的dubbo版本一致。 https://github.com/alibaba/dubbo/releases 2、maven instal…

前端架构设计1:代码核心

现在的前端领域, 随着JS框架, UI框架和各种库的丰富, 前端架构也变得十分的重要. 如果一个大型项目没有合理的前端架构设计, 那么前端代码可能因为不同的开发人员随意的引入各种库和UI框架, 导致代码量变得异常臃肿, 最终结果可能是代码变得无法维护, 页面性能低下,不得已只能推…

如何用法向量求点到平面距离_支持向量机(SVM)

最近完成的一个项目用到了SVM&#xff0c;之前也一直有听说支持向量机&#xff0c;知道它是机器学习中一种非常厉害的算法。利用将近一个星期的时间学习了一下支持向量机&#xff0c;把原理推了一遍&#xff0c;感觉支持向量机确实挺厉害的&#xff0c;尤其是核函数变换可以把一…

TortoiseSVN 1.9.5安装 与 Eclipse4.4.2中安装SVN插件 图解详解

原文链接&#xff1a;http://blog.csdn.net/chenchunlin526/article/details/54631458 Eclipse svn 插件官网&#xff1a;http://subclipse.tigris.org/ Eclipse svn 插件更新网站&#xff1a;https://github.com/subclipse/subclipse/wiki -------------------------------…

虚拟服务器关机返回用户信息,在Linux服务器关机前向用户显示一条自定义消息...

在先前的文┞仿中&#xff0c;我们说清楚明了 Linux 中 shutdown、poweroff、halt、reboot 敕令的不合之处&#xff0c;并揭示了在用不合的选项履行这些敕令时它们实际做了什么。# shutdown 13:25本篇将会向你展示如安在体系关机时向所有的体系用户发送一条自定义的消息。建议浏…

eclipse svn不能忽略文件及文件夹,ignore设置无效 ?

SVN这块做得不好&#xff0c;如果之前提交过此文件&#xff0c;就不能设置忽略该文件了。所以第一次提交的时候要搞清楚再提交。 【 亲测&#xff0c;的确如此&#xff0c;用 Windows -> Preferences -> Team -> Ignored Resources 方法不行。 项目右键--team--设置…

华为服务器产品系列号查询,华为LIST全系列 服务器产品速查清单

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼型号 描述S5700-EI-AC-B09 S5700-52C-EI交换机(48个10/100/1000Base-T RJ45,2个10GE SFP上行口, 含堆叠卡)S5700-EI-AC-B06 S5700-28C-EI交换机(24个10/100/1000Base-T RJ45,2个10GE SFP上行口, 含堆叠卡)FC0M00S67403 S6748-EI交换…

BZOJ4300 绝世好题

目录 BZOJ4300 绝世好题题解&#xff43;&#xff4f;&#xff44;&#xff45;BZOJ4300 绝世好题 题目传送门 题解 比较简单的\(DP\)&#xff0c;记\(f[i]\)表示第\(i\)位为&#xff11;&#xff0c;最长的长度为多少。只需要枚举每一个数字&#xff0c;对于这个数字二进制下…

Sonatype Nexus 库被删除的恢复方法

原文连接&#xff1a;https://my.oschina.net/u/178116/blog/519840 --------------------有道云笔记保存---------------------------------------------- 今天在整理公司Maven私服的时候&#xff0c;不小心把Release库删掉了。瞬间冒出冷汗来了&#xff01;公司所有的积累都…

hbase 修改表名_hbase修改表名 - 张欢19933的个人空间 - OSCHINA - 中文开源技术交流社区...

hbase修改表名hbase修改表名没有直接的api可以调用&#xff0c;我们如果想要修改表名&#xff0c;可以利用快照的方式。需要开启快照功能&#xff0c;在hbase-site.xml文件中添加如下配置项&#xff1a;hbase.snapshot.enabledtrue命令hbase shell> disable tableNamehbase …

ajax一次输出1万条数据库,后端接口一次给出100万条数据,请问你前端怎么分页处理...

面试官既然能这么问&#xff0c;我们从技术的角度出发&#xff0c;探索一下这道题&#xff0c;上手操作了一下&#xff1a;function loadAll(response) {var html "";for (var i 0; i < 100000; i) {html "title:" 我正在测试[i] "";}$(…

“” '' ``区别 初学者自用

单引号 相当于吧里面的内容直接输出。并不会考虑里面是否有变量命令等双引号 "" 只认变量 命令会直接输出反引号 两种都认 实例&#xff1a; a"hello" [localhost.localdomain 10:16:09]$echo echo %a输出&#xff1a;echo %a [localhost.localdomain…

maven私有库配置

不同的项目&#xff0c;不同的私有库1、添加仓库Release 发布&#xff1b; 发行仓库snapshot 快照&#xff0c;开发&#xff0c;调试仓库配置完成2、配置权限默认开通的权限&#xff0c;查看权限给刚才建的两个私有库添加权限配置好后3、创建角色&#xff0c;分配权限添加rolei…