微信小程序的跨页面传参以及data-方法的相关细节

在这里插入图片描述
🙂博主:小猫娃来啦
🙂文章核心:微信小程序的跨页面传参以及data-方法的相关细节

目录

  • 前言
  • `wx.navigateTo()`方法
  • 微信小程序传参的几种方式
  • 通过`data-`属性传参
  • 关于data-方法配合点击事件传参的细节

前言

其实在学习新东西的过程中,最快速的方式就是多看官方文档。
很多技术层面的东西,官方文档其实讲的很清楚了。
vue这个渐进式框架在很久以前,是没有多少官方文档供人学习的,但现在慢慢都完善了。更是有高级文档。react官方文档,官方都看不下去了,后来进行了重改。可以说都在变化,都在朝好的方向发展。
微信小程序,只不过不像其他文档看起来可读,因为没有可视化的例子。全是干巴巴的文字,这个需要一个api一个api的试,才知道是干嘛的。这也给很多人造成了困扰,其实,微信小程序官方文档是非常完善的。很多东西都有,都很齐备。

你说你学不会微信跨页面传参,拜托你去看看官方文档好不好~~~

不用,我给你搬过来了


wx.navigateTo()方法

⭐wx.navigateTo()是小程序框架提供的跳转页面方法之一,用于打开新的页面,并保留当前页面在导航栈中。具体介绍如下:

函数定义:

wx.navigateTo(Object object)

参数说明:

  • Object object:跳转的目标页面信息配置对象,包括以下属性:
  • url(必填):要跳转的页面路径(需在app.json中进行注册)。
  • success:跳转成功的回调函数。
  • fail:跳转失败的回调函数。
  • complete:跳转完成的回调函数。

跳转流程:

  1. 小程序从当前页面跳转到指定页面,指定页面将会被加载和显示。
  2. 当前页面会被隐藏,但仍保留在小程序的导航栈中,可以通过返回操作返回到该页面。

注意事项:

  • 目标页面的路径需要在 app.json 的 pages 字段中进行注册,才能跳转到该页面。
  • 跳转的目标页面路径不得超过10层。
  • 小程序中同时存在的页面数量不能超过10个。

示例代码:

// 在当前页面调用 navigateTo 跳转到目标页面
wx.navigateTo({url: '/pages/targetPage/targetPage',success: function () {console.log('跳转成功')},fail: function (err) {console.log('跳转失败', err)},complete: function () {console.log('跳转完成')}
})

简而言之,通过wx.navigateTo这个方法可以在小程序中实现页面之间的跳转。
如果在跳转的时候,我需要携带数据跳转呢?
也就是说如何跨页面将参数传过去?


微信小程序传参的几种方式

在微信小程序中,可以通过以下几种方式实现页面之间的参数传递:

1.URL参数传递:可以在跳转页面时,在URL中添加参数信息,目标页面可以通过options参数获取。例如:

// 页面A跳转到页面B并传递参数
wx.navigateTo({url: '/pages/pageB/pageB?key=value',
})

在页面B的onLoad方法中接参:

onLoad: function(options) {console.log(options.key); // 输出'value'
}

2.全局变量或缓存传递:可以使用全局变量或小程序的缓存机制来存储数据,并在目标页面中读取和使用。例如:

// 在页面A中设置全局变量或缓存数据
getApp().globalData.key = 'value';// 在页面B中获取全局变量或缓存数据
console.log(getApp().globalData.key); // 输出'value'

3.使用事件总线传递:可以通过事件总线机制来进行页面间的参数传递。可以在全局范围内定义一个事件触发和监听的机制,页面A触发事件并携带参数,页面B监听事件并接收参数。具体实现可以使用第三方库如miniprogram-event。例如:

// 页面A中触发事件并传递参数
const Event = require('path/to/miniprogram-event');
Event.emit('eventName', { key: 'value' });// 页面B中监听事件并接收参数
const Event = require('path/to/miniprogram-event');
Event.on('eventName', (params) => {console.log(params.key); // 输出'value'
});

这些方法可以根据具体场景选择使用,根据应用的复杂程度和数据大小来选取最合适的方式。


通过data-属性传参

在标签上使用data-*属性来设置参数值。例如,在一个按钮上设置参数为"123":

<button data-param="123" bindtap="handleClick">点击按钮</button>

在对应的页面JS文件中编写事件处理函数,并通过event.currentTarget.dataset来获取传递的参数。

Page({handleClick: function(event) {// 获取传递的参数值var param = event.currentTarget.dataset.param;console.log(param); // 输出"123"}
})

在点击事件处理函数中,通过event.currentTarget可以获取当前触发事件的组件信息,其中dataset对象存储了所有以data-开头的属性和对应的值。使用event.currentTarget.dataset.param即可获取到传递的参数值。

这样就实现了使用data-*方法进行参数的传递和接收。通过设置不同的data-*属性值,可以在事件处理函数中获取到不同的参数值,方便进行后续的操作。


关于data-方法配合点击事件传参的细节

这里面有几个细节,我们来看一下。

页面A传参:
在这里插入图片描述⭐⭐⭐细节一:在本页面进行渲染,这个wx:for相当于vue当中的v-for。将这一部分循环渲染,并且给每个图片标签绑定点击事件activityDetail,每张图片都对应一条数据,每条数据都对应一个唯一标识,也就是id,也就是这里的item.id。在点击图片的时候需要跳转到另一个页面的同时携带这个item.id,在另一个页面,这个item.id对应接口的请求参数,item.id不一样,接口返回的数据也不一样,我们需要根据返回的不同数据进行渲染。最终的效果就是点击上一个页面不同的图片,跳转到另一个页面显示不同的内容。

⭐⭐⭐细节二:data-后面的东西叫参数名,这个可以随便起。

本页面的js:

  activityDetail(e) {console.log(e);let cardId = e.target.dataset.cardid;wx.navigateTo({url: '../activityDetail/activityDetail?cardId=' + cardId,})},

⭐⭐⭐细节三:这个e是什么?
在这里插入图片描述我特意打印了这个e,在107行,这个e是个对象,里面有很多对象,比如这个target,展开后是这样的:
在这里插入图片描述
也就是我们要将这个e里面的cardid:31拿到,并传到另一个页面
所以我们才有了这句话:

    let cardId = e.target.dataset.cardid;

然后是这句话:

    wx.navigateTo({url: '../activityDetail/activityDetail?cardId=' + cardId,})


那么在页面B,我们要接参:

在这里插入图片描述
打印了一下这个options
在这里插入图片描述获取到了,用的时候就是options.carId拿值即可,仅此而已。

至此跨页面传参已经结束,本篇博客也结束了,如果你觉得有帮助,请三连支持一下吧🙂🙂🙂
在这里插入图片描述


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

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

相关文章

【Twitter爬虫】Twitter网络爬虫

利用selenium爬取Twitter 从2月9日起&#xff0c;Twitter不再支持免费访问Twitter API&#xff0c;继续使用Twitter API支付较高的费用。下面将介绍一种绕过Twitter API爬取推文的方式 Selenium Webdriver框架 首先介绍一下Selenium Webdriver&#xff0c;这是一款web自动化…

R+VIC 模型融合实践技术应用及未来气候变化模型预测

目前&#xff0c;无论是工程实践或是科学研究中都存在很多著名的水文模型如SWAT/HSPF/HEC-HMS等。虽然&#xff0c;这些软件有各自的优点&#xff1b;但是&#xff0c;由于适用的尺度主要的是中小流域&#xff0c;所以在预测气候变化对水文过程影响等方面都有所不足。 VIC模型…

Web服务器群集:部署Tomcat

目录 一、理论 1.Tomcat 2.JDK 3.Tomcat安装 4.Tomcat优化 5.Tomcat虚拟主机设置 二、实验 1.JDK安装 2.Tomcat安装 3.Tomcat优化 4.Tomcat 虚拟主机配置 三、总结 一、理论 1.Tomcat &#xff08;1&#xff09;概念 Tomcat服务器是一个免费的开放源代码的Web应用…

UE5 读写本地JSON,发送HTTP请求(get)

UE5 读写本地JSON&#xff0c;发送HTTP请求&#xff08;get&#xff09; 没有使用插件&#xff0c;就用UE提供的库开发&#xff08;推荐使用插件VaRest在虚幻商城里有&#xff09; PCHUsage PCHUsageMode.UseExplicitOrSharedPCHs;PublicDependencyModuleNames.AddRange(new …

vue 启动项目报错:TypeError: Cannot set property ‘parent‘ of undefined异常解决

场景&#xff1a;从git上面拉下来一个项目 npm i 下载完依赖以后 npm run serve 去运行项目的时候 报错TypeError: Cannot set property ‘parent’ of undefined 如图所示 原因&#xff1a;首先排查发现判断得出是less解析失败导致 但是经过长时间的查询解决方案发现是因为v…

DAY39——动态规划part2

1.考虑障碍在起点和终点的特殊状况&#xff0c;可直接返回0 2.判断是否存在障碍物&#xff1a;初始化时需要设置障碍物后的坐标为0

windows环境使用cmake配置pcl

安装环境 cmake版本&#xff1a;cmake-3.26.3-windows-x86_64 pcl版本&#xff1a;PCL 1.13.1 vs版本&#xff1a;vs2022 配置流程 cmake编译准备&#xff1a;新建两个文件夹source和cmake_bin。source用于存放.cpp文件和CMakeLists.txt 文件&#xff1b;cmake_bin存放配置生…

【Java】Java核心 73:XML (中)

文章目录 5 XML的组成&#xff1a;字符区(了解)**6** **DTD约束(能够看懂即可)****1** **什么是DTD****2** **DTD约束的实现和语法规则&#xff08;看懂dtd约束&#xff0c;书写符合规范的xml文件&#xff09;** 5 XML的组成&#xff1a;字符区(了解) 当大量的转义字符出现在x…

「网络编程」第二讲:网络编程socket套接字(一)

「前言」文章是关于网络编程的socket套接字方面的&#xff0c;下面开始讲解&#xff01; 「归属专栏」网络编程 「笔者」枫叶先生(fy) 「座右铭」前行路上修真我 「枫叶先生有点文青病」 「每篇一句」 春风得意马蹄疾&#xff0c;一日看尽长安花。 ——孟郊《登科后》 目录 一…

【Python笔记】之-bash: python: command not found

问题&#xff1a; 在服务器环境&#xff0c;使用python命令时提示&#xff1a;-bash: python: command not found 查看服务器python版本&#xff0c;一般是在/usr/bin目录下&#xff0c;在终端输入命令如下&#xff1a; find /usr/bin -iname python*得到输出&#xff1a; …

Android Compose Button defaultButtonColors

Android Compose Button defaultButtonColors 本文最新更新地址 https://gitee.com/chenjim/chenjimblog 发现问题 最近看 Android Compose 相关资料发现如下代码 colors defaultButtonColors( backgroundColor if (count > 5) Color.Green else Color.White )原文地…

Elasticsearch:使用 SIMD 指令加速向量搜索

作者&#xff1a;Chris Hegarty, Elastic Principal Engineer, Lucene PMC 翻译&#xff1a;杰瑞朱 多年来&#xff0c;Java 平台上运行的代码一直受益于自动向量化 —— HotSpot C2 编译器中的 superword 优化&#xff0c;将多个标量操作打包到 SIMD&#xff08;单指令多数据…