微信小程序和H5之间互相跳转、互相传值
创始人
2024-02-04 23:39:45
0

最近又开始写小程序了,刚好遇到微信小程序和内嵌 H5 之间来回跳转,来回交互;这里记录一下微信小程序和 H5 之间交互的实现;(我的小程序是通过 un-app 框架来写的,内部代码基本都是 vue)

文章目录

        • 一、微信小程序跳转 H5
          • 1、web-view
        • 二、H5跳微信小程序
          • 1、H5 直接跳到微信小程序
          • 2、内嵌H5跳转到微信小程序
        • 三、微信小程序传值给内嵌H5
          • 1、路径传参
        • 四、内嵌H5传值给微信小程序
          • 1、用 postMessage
          • 2、路径传参

一、微信小程序跳转 H5

1、web-view

微信小程序官方提供了 web-view 组件来实现微信小程序跳转到 H5 页面,实现的方式也很简单,具体实现方式如下:
1、新建一个页面用来单独存放 web-view 组件,并且所有的内嵌 H5 都可以通过这个页面来实现跳转;

//web-view

export default{data(){return{url:''}},onLoad(option){this.url = option.url}
}

其他小程序页面跳转只需要将 H5 的地址拼接在路径上;

//其他小程序页面
let url = 'xxxx';
uni.navigateTo({url: `/pages/webview/webview?url=${url}`
})

二、H5跳微信小程序

H5 往微信小程序跳转需要借助微信 JS-SDK(官方文档),官方提供的是引入 js 文件的方式来使用微信 JS-SDK;当然在 vue 的项目里我们还可以以依赖的方式来安装:weixin-js-sdk;

1、H5 直接跳到微信小程序

可以借助微信 sdk 里面的标签( wx-open-launch-weapp)直接跳转;不过这种方式需要申请配置:

  1. 已认证的服务号(公众号),服务号绑定“JS接口安全域名”下的网页可使用此标签跳转任意合法合规的小程序。
  2. 已认证的非个人主体的小程序,使用小程序云开发的静态网站托管绑定的域名下的网页,可以使用此标签跳转任意合法合规的小程序。


这种方式可以跳转到任何小程序,跳转的同时,H5页面可以把需要传递的参数通过 path 路径拼接的方式将参数传递过去;
可参考:开发标签说明文档

2、内嵌H5跳转到微信小程序

这种不需要配置,直接就可以通过微信 sdk 提供的方法来实现跳转;注意:只能跳转回当前小程序;

wx.miniProgram.navigateTo({url:''})
wx.miniProgram.navigateBack({url:''})
wx.miniProgram.switchTab({url:''})
wx.miniProgram.reLaunch({url:''})
wx.miniProgram.redirectTo({url:''})

完整的操作应该是:

//先判断当前环境是小程序环境
wx.miniProgram.getEnv(function(res){if(res.miniprogram){//跳转到小程序页面wx.miniProgram.navigateTo({url:"/pages/xxx"})}
})

三、微信小程序传值给内嵌H5

1、路径传参

小程序直接通过修改 web-view 的 src 属性就行了,将需要传递的参数拼接在路径上,H5 页面之间通过 query 来拿参数;

//其他小程序页面
let url = 'xxxx?name=xxx&number=123';
uni.navigateTo({url: `/pages/webview/webview?url=${url}`
})

四、内嵌H5传值给微信小程序

以下两种方式都需要在 H5 的 index.html 页面引入下面 js:


1、用 postMessage

在 web-view 组件上有一个属性 bindmessage ,网页向小程序 postMessage 时会触发并接收消息;

//web-view

export default{data(){return{url:''}},onLoad(option){this.url = option.url}methods:{getMessage(e){//接收参数,也可以跳转到小程序其他页面将参数传递过去console.log(e.detail)}}
}
//H5页面
wx.miniProgram.postMessage({ data: {name: 'xxx'} })
2、路径传参

调用微信 wx.miniProgram API 跳转到小程序页面时,通过路径拼接把参数传递过去;

wx.miniProgram.navigateTo({url:"/pages/xxx/xxx/xxx?name=xxx"
});

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...