微信小程序间用navigator跳转时如何实现长尾词参数传递?

2026-04-03 09:081阅读0评论SEO基础
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计738个文字,预计阅读时间需要3分钟。

微信小程序间用navigator跳转时如何实现长尾词参数传递?

本文实例讲述了微信小程序间使用 navigator 跳转传递值的问题。分享给家长供参考。

前言:本次讲座将以下面为例,讲解我使用 navigator 组件实现从一个小程序跳转到另一个小程序的过程及遇到的疑问。

我使用 navigator 组件实现从一个小程序跳转到另一个小程序,但在跳转过程中遇到了传递值的问题。具体来说,当我在跳转时尝试传递一些数据,但发现在目标小程序中接收到的数据不准确或丢失。请问这是为什么?应该如何解决?

本文实例讲述了微信小程序间使用navigator跳转传值问题。分享给大家供大家参考,具体如下:

前言

这次讲一下我用 navigator 组件实现从一个小程序跳转到另一个小程序的过程中遇到的问题。

extra-data 如何构建

由于上网查资料得知 extra-data 是 json 格式。那么就不能在 HTML 属性中直接写。

那么剩下只有在 JS 里构建了。

首先在 HTML 里,绑定 extra-data的值到 extra 变量

<navigator class="navi" url="" target="miniProgram" app-id="wxxxxxxxxxxxxxxx" extra-data="{{ extra }}" version="{{ version }}" path="/pages/index/index"> <image src="{{img}}" mode="scaleToFill" class="img"> </image> </navigator>

然后在 JS 里构建这个变量

Page({ data: { extra: { "color": '', // 动态获取 "partnerUsername": '99', }, }, })

这里有个问题,就是如果 extra 里的 color 等变量是动态从远程 api 获取到的,那么应该怎么赋值。

我凭直觉写 extra.color = 'xx' ,尝试了下不行。查阅资料发现,应该这么写:

wx.request({ url: url, data: { color: '', }, header: { 'content-type': 'application/json' }, success: function (res) { that.setData({ "extra.color": app.globalData.color, }); } });

还可以在 path 属性值后面跟参数来向目标小程序传值

通过搜索发现[这篇文章](cloud.tencent.com/developer/article/1157552),我试了他给出的解决方案,是可行的,现在记录在下面:

<navigator class="navi" url="" target="miniProgram" app-id="wxxxxxxxxxxxx" version="{{ version }}" path="zh_tcwq/pages/index/index?color={{ colorSet }}&partner={{ partner }}"> <image src="{{src}}" mode="scaleToFill" class="img"> </image> </navigator>

// 源小程序 this.setData({ colorSet: app.globalData.color, partner: app.globalData.partnerUsername, });

// 目标小程序 onShow: function (options) { console.log(options.query.color + options.query.partner); }

奇怪的问题(可能是bug):打开调试时,目标小程序能获取到动态的 extra-data,关闭后无法获取到

原因是我没配合法域名,所以动态从 api 获取的数据获取不到。

微信小程序间用navigator跳转时如何实现长尾词参数传递?

希望本文所述对大家微信小程序开发有所帮助。

本文共计738个文字,预计阅读时间需要3分钟。

微信小程序间用navigator跳转时如何实现长尾词参数传递?

本文实例讲述了微信小程序间使用 navigator 跳转传递值的问题。分享给家长供参考。

前言:本次讲座将以下面为例,讲解我使用 navigator 组件实现从一个小程序跳转到另一个小程序的过程及遇到的疑问。

我使用 navigator 组件实现从一个小程序跳转到另一个小程序,但在跳转过程中遇到了传递值的问题。具体来说,当我在跳转时尝试传递一些数据,但发现在目标小程序中接收到的数据不准确或丢失。请问这是为什么?应该如何解决?

本文实例讲述了微信小程序间使用navigator跳转传值问题。分享给大家供大家参考,具体如下:

前言

这次讲一下我用 navigator 组件实现从一个小程序跳转到另一个小程序的过程中遇到的问题。

extra-data 如何构建

由于上网查资料得知 extra-data 是 json 格式。那么就不能在 HTML 属性中直接写。

那么剩下只有在 JS 里构建了。

首先在 HTML 里,绑定 extra-data的值到 extra 变量

<navigator class="navi" url="" target="miniProgram" app-id="wxxxxxxxxxxxxxxx" extra-data="{{ extra }}" version="{{ version }}" path="/pages/index/index"> <image src="{{img}}" mode="scaleToFill" class="img"> </image> </navigator>

然后在 JS 里构建这个变量

Page({ data: { extra: { "color": '', // 动态获取 "partnerUsername": '99', }, }, })

这里有个问题,就是如果 extra 里的 color 等变量是动态从远程 api 获取到的,那么应该怎么赋值。

我凭直觉写 extra.color = 'xx' ,尝试了下不行。查阅资料发现,应该这么写:

wx.request({ url: url, data: { color: '', }, header: { 'content-type': 'application/json' }, success: function (res) { that.setData({ "extra.color": app.globalData.color, }); } });

还可以在 path 属性值后面跟参数来向目标小程序传值

通过搜索发现[这篇文章](cloud.tencent.com/developer/article/1157552),我试了他给出的解决方案,是可行的,现在记录在下面:

<navigator class="navi" url="" target="miniProgram" app-id="wxxxxxxxxxxxx" version="{{ version }}" path="zh_tcwq/pages/index/index?color={{ colorSet }}&partner={{ partner }}"> <image src="{{src}}" mode="scaleToFill" class="img"> </image> </navigator>

// 源小程序 this.setData({ colorSet: app.globalData.color, partner: app.globalData.partnerUsername, });

// 目标小程序 onShow: function (options) { console.log(options.query.color + options.query.partner); }

奇怪的问题(可能是bug):打开调试时,目标小程序能获取到动态的 extra-data,关闭后无法获取到

原因是我没配合法域名,所以动态从 api 获取的数据获取不到。

微信小程序间用navigator跳转时如何实现长尾词参数传递?

希望本文所述对大家微信小程序开发有所帮助。