微信小程序页面之间的传值方式

在微信小程序的开发过程中,页面之间的传值是一个常见的操作。根据多年的实践,我就我所知道的小程序页面之间的传值方式,进行简单的总结。希望能够帮助大家。

一、URL参数传递

  1. 原理
  • 这种方式类似于网页开发中的URL传参。在微信小程序中,我们可以通过在navigator组件的url属性中添加参数来实现页面间传值(这种方式类似于浏览器路由中的search进行传值)。例如,当我们从页面A跳转到页面B时,可以在navigator的url中添加类似?key=value的参数。
  • 页面B可以通过onLoad生命周期函数获取这些参数。onLoad函数的参数options是一个对象,其中包含了从其他页面传递过来的参数。
  1. 示例代码
  • 在页面A的wxml文件中,假设我们有一个navigator组件用于跳转到页面B:
<navigator url="'/pages/pageB/pageB?name=John&age=20">跳转到页面B</navigator>
  • 或者在页面A中的控制脚本中,我们点击一个按钮,调用方法navigateTo,来进行跳转到页面B:
wx.navigateTo({url: '/pages/pageB/pageB?name=John&age=20'
});
  • 在页面B的js文件中,在onLoad函数中获取参数:
Page({onLoad: function(options) {console.log(options.name); // 输出: Johnconsole.log(options.age); // 输出: 20}
});

二、全局变量

  1. 原理
  • 微信小程序提供了app.js文件,它是整个小程序的全局应用对象。我们可以在app.js中定义全局变量,然后在不同的页面中访问和修改这些变量。这种方式适用于在多个页面之间共享数据,并且数据的改变可能会影响多个页面的显示情况。
  1. 示例代码
  • 在app.js文件中定义全局变量:
App({globalData: {userInfo: null}
});
  • 在页面A中设置全局变量的值:
const app = getApp();
Page({onLoad: function() {app.globalData.userInfo = {name: 'Alice', age: 22};}
});
  • 在页面B中获取全局变量的值:
const app = getApp();
Page({onLoad: function() {console.log(app.globalData.userInfo);}
});

三、事件总线(Event Bus)

  1. 原理
  • 事件总线是一种基于发布 - 订阅模式的传值方式。我们可以创建一个事件中心,在一个页面发布事件并传递数据,然后在其他订阅了该事件的页面接收数据。
  • 这种方式比较灵活,适用于页面之间没有直接关联(如不是父子关系等)的情况。
  1. 示例代码
  • 首先创建一个事件总线的工具文件(例如eventBus.js):
let eventBus = {eventList: {},on: function(eventName, callback) {if (!this.eventList[eventName]) {this.eventList[eventName] = [];}this.eventList[eventName].push(callback);},emit: function(eventName, data) {if (this.eventList[eventName]) {this.eventList[eventName].forEach(callback => {callback(data);});}}
};
module.exports = eventBus;
  • 在页面A中发布事件并传递数据:
const eventBus = require('../../utils/eventBus.js');
Page({
onLoad: function() {let data = {message: '这是从页面A传递的数据'};eventBus.emit('dataTransferEvent', data);}
});
  • 在页面B中订阅事件并接收数据:
const eventBus = require('../../utils/eventBus.js');
Page({onLoad: function() {eventBus.on('dataTransferEvent', function(data) {console.log(data.message);});}
});

四、使用本地存储(Storage)

  1. 原理
  • 微信小程序提供了本地存储wx.setStorageSync和wx.getStorageSync等方法。我们可以在一个页面将数据存储到本地存储中,然后在另一个页面从本地存储中获取数据。这种方式相对来说比较适合数据持久化存储和跨会话(用户关闭小程序后重新打开)的数据传递。
  1. 示例代码
  • 在页面A中存储数据:
Page({onLoad: function() {let data = {key: 'value'};wx.setStorageSync('dataKey', data);}
});
  • 在页面B中获取数据:
Page({onLoad: function() {let retrievedData = wx.getStorageSync('dataKey');console.log(retrievedData);}
});

五、使用页面栈(只对当前页面栈中存在的页面生效)

  • A页面部分js代码
 Page({data:{name:'斗帝蓝电霸王龙Pro',age:22},eatFood:function(food){console.log('eating '+ food)    }})
  • B页面部分js代码
 Page({onLoad: function (options) {// 获取当前页面栈const pages = getCurrentPages();// 获取上一页面对象let prePage = pages[pages.length - 2];console.log(prePage.data.name) // 斗帝蓝电霸王龙ProprePage.eatFood('斗帝蓝电霸王龙Pro') // eating 斗帝蓝电霸王龙Pro}})

以上就是微信小程序中常见的页面之间传值方式。在实际开发中,我们可以根据具体的业务场景和页面之间的关系来选择合适的传值方式,以达到高效、稳定的数据传递效果。

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

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

相关文章

cursor保存更改操作技巧

1. 当我们在agent模式时&#xff0c;要求cursor更改代码时&#xff0c;cursor回答后&#xff0c;就已经更改了代码了&#xff0c;这时候就可以对程序进行编译和测试&#xff0c; 不一定先要点” accept“, 先测试如果没有问题再点“accept”&#xff0c;这样composer就会多一条…

运维工程师面试系统监控与优化自动化与脚本云计算的理解虚拟化技术的优点和缺点

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c; 忍不住分享一下给大家。点击跳转到网站 学习总结 1、掌握 JAVA入门到进阶知识(持续写作中……&#xff09; 2、学会Oracle数据库入门到入土用法(创作中……&#xff09; 3、手把…

2.在 Vue 3 中使用 ECharts 实现动态时间轴效果

在前端开发中&#xff0c;时间轴&#xff08;Timeline&#xff09;是一种常见且有效的方式来展示时间相关的数据。在本篇文章中&#xff0c;我们将展示如何在 Vue 3 项目中使用 ECharts 创建一个具有动态时间范围的时间轴&#xff0c;并添加了今日时间的标记以及通过按钮来前进…

Android修行手册 - 移动端几种常用动画方案对比

Unity3D特效百例案例项目实战源码Android-Unity实战问题汇总游戏脚本-辅助自动化Android控件全解手册再战Android系列Scratch编程案例软考全系列Unity3D学习专栏蓝桥系列ChatGPT和AIGC &#x1f449;关于作者 专注于Android/Unity和各种游戏开发技巧&#xff0c;以及各种资源分…

Java日志框架:log4j、log4j2、logback

文章目录 配置文件相关1. properties测试 2. XMl使用Dom4j解析XML Log4j与Log4j2日志门面 一、Log4j1.1 Logges1.2 Appenders1.3 Layouts1.4 使用1.5 配置文件详解1.5.1 配置根目录1.5.2 配置日志信息输出目的地Appender1.5.3 输出格式设置 二、Log4j22.1 XML配置文件解析2.2 使…

《信管通低代码信息管理系统开发平台》Linux环境安装说明

1 简介 信管通低代码信息管理系统应用平台提供多环境软件产品开发服务&#xff0c;包括单机、局域网和互联网。我们专注于适用国产硬件和操作系统应用软件开发应用。为事业单位和企业提供行业软件定制开发&#xff0c;满足其独特需求。无论是简单的应用还是复杂的系统&#xff…

HTTPS协议原理与CA认证

目录 引言 HTTPS 是什么 1.什么是"加密" 2. 为什么要加密 3. 常⻅的加密⽅式 对称加密 ⾮对称加密 4.数据摘要 && 数据指纹 5. 数字签名 HTTPS 的⼯作过程探究 ⽅案 1 - 只使⽤对称加密 ⽅案 2 - 只使⽤⾮对称加密 ⽅案 3 - 双⽅都使⽤⾮对称加密…

vulnhub靶场——Log4j2

第一步:搭建靶场环境 #开启环境 cd vulhub/log4j/CVE-2021-44228 docker-compose up -d 来到网站首页 第二步:搭建一个dnslog平台上获取我们注入的效果 第三步:发现 /solr/admin/cores?action 这里有个参数可以传 我们可以看到留下了访问记录并且前面的参数被执行后给我们回…

使用idea创建JDK8的SpringBoot项目

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 使用idea创建JDK8的SpringBoot项目 前言我们经常在创建新的springboot项目&#xff0c;默认使用的是spring.io进行创建&#xff0c;但是它总是只会提供高版本的创建方式&…

U9多组织销退业务流程的总结

多组织销退业务流程&#xff0c;它的运行模式也是奇葩&#xff0c;确实不好理解其中的道理。用户实践中更是障碍重重&#xff0c;束手无策。左也不是右也不是&#xff0c;无路可走。 不能理解透彻造成的吧&#xff0c;所以做一个总结。 既有退货&#xff0c;必有出货单。从出货…

cudnn版本gpu架构

nvcc --help 可以看 --gpu-architecture 写到的支持的架构 NVIDIA 的 GPU 架构是按代次发布的&#xff0c;以下是这些架构的对应说明&#xff1a; NVIDIA Hopper: 这是 NVIDIA 于 2022 年推出的架构之一&#xff0c;面向高性能计算&#xff08;HPC&#xff09;和人工智能&…

Prompt格式到底有多重要?它竟然这样影响LLM函数调用能力(附提示词模版)

函数调用能力的关键地位 在当前大语言模型&#xff08;LLM&#xff09;的应用生态中&#xff0c;函数调用能力&#xff08;Function Calling&#xff09;已经成为一项不可或缺的核心能力。它使LLM能够通过调用外部API获取实时信息、操作第三方服务&#xff0c;从而将模型的语言…

有了chatgpt4o,普通人还需要学代码吗?

或许AI到达“终极智能”时&#xff0c;普通人就不用学代码了。不过现阶段或很长的一段时间内这还是不可能的。目前AI编程还是以辅助编程为主&#xff0c;普通人可以借助AI实现一些简单的编程。 其实这个问题可以扩大到AI编程的出现对编程行业或程序员职业影响的问题。就这个问…

CE8.【C++ Cont】练习题组6

目录 1.矩阵转置 题目描述 输入格式 输出格式 输入输出样例 错误代码 提交结果 正确代码 提交结果 2.图像相似度 题目描述 输入格式 输出格式 输入输出样例 代码 提交结果 3. 计算矩阵边缘元素之和 题目描述 输入格式 输出格式 输入输出样例 说明/提示 …

哪个网页版思维导图好用?这5款高效软件不容错过!

眼下虽然每个人的电脑硬盘越来越大&#xff0c;但很多人还是保留着“能不装软件就不装”的理念&#xff0c;在选择办公软件时&#xff0c;会更倾向于选用推出了网页版的软件&#xff0c;这对思维导图来说也不例外。 那具体到思维导图网页版&#xff0c;有哪些软件值得推荐&…

【双指针算法】--复写零

文章目录 1. 题目2. 题目解析3. 代码 1. 题目 在线oj 给你一个长度固定的整数数组 arr &#xff0c;请你将该数组中出现的每个零都复写一遍&#xff0c;并将其余的元素向右平移。 注意&#xff1a;请不要在超过该数组长度的位置写入元素。请对输入的数组 就地 进行上述修改&a…

石岩基督教福音堂

周末娃&#xff0c;娃的阿婆和我一起去石岩基督教福音堂做礼拜。 这是我第一次进入石岩的教堂。教堂很高。应该有3,4层楼高。 这周末做礼拜的人很多一楼人满了&#xff0c;阿婆去二楼做礼拜&#xff0c;娃和我去三楼的儿童室。很多家长楼下做礼拜&#xff0c;小朋友被安排三楼…

Flutter 异步编程简述

1、isolate 机制 1.1 基本使用 Dart 是基于单线程模型的语言。但是在开发当中我们经常会进行耗时操作比如网络请求&#xff0c;这种耗时操作会堵塞我们的代码。因此 Dart 也有并发机制 —— isolate。APP 的启动入口main函数就是一个类似 Android 主线程的一个主 isolate。与…

IDEA用jformdesigner插件做管理系统MVC架构

在 IntelliJ IDEA 中结合 JFormDesigner 插件&#xff0c;通过 Swing 框架实现一个管理系统的 MVC 架构是一种经典的开发方式。以下是具体的步骤和实现思路&#xff0c;包含从项目创建到 MVC 架构的核心代码实现。 1. 项目结构设计 为了清晰的 MVC 分层架构&#xff0c;建议按…

Linux内核调度优先级详解:如何优化你的系统性能

个人主页&#xff1a;chian-ocean 文章专栏-Linux 前言&#xff1a; 进程优先级调度是操作系统中的一种调度机制&#xff0c;其核心是为每个进程分配一个 优先级&#xff08;Priority&#xff09;&#xff0c;然后根据优先级的高低决定进程执行的顺序和时间。这种机制确保了关…