HTML5页面打开微信小程序功能实现


Posted in HTML / CSS onSeptember 23, 2022

微信终于支持由页面跳转至小程序啦 ~

HTML5页面打开微信小程序功能实现

步骤一:绑定域名

登录微信公众平台进入“公众号设置”的“功能设置”里填写“JS接口安全域名”。

步骤二:引入JS文件

在需要调用JS接口的页面引入如下JS文件:http://res.wx.qq.com/open/js/jweixin-1.6.0.js(支持https)

如需进一步提升服务稳定性,当上述资源不可访问时,可改访问:http://res2.wx.qq.com/open/js/jweixin-1.6.0.js(支持https)

备注:支持使用 AMD/CMD 标准模块加载方法加载。

步骤三:通过config接口注入权限验证配置并申请所需开放标签

与使用JS-SDK配置方式相同,所有需要使用开放标签的页面必须先注入配置信息,并通过openTagList字段申请所需要的开放标签,否则将无法使用(同一个url仅需调用一次)。开放标签的申请和JS接口的申请相互独立,因此是可以同时申请的。

微信JS-SDK说明文档

wx.config({
  debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印
  appId: '', // 必填,公众号的唯一标识
  timestamp: , // 必填,生成签名的时间戳
  nonceStr: '', // 必填,生成签名的随机串
  signature: '',// 必填,签名
  jsApiList: [], // 必填,需要使用的JS接口列表
  openTagList: [] // 可选,需要使用的开放标签列表,例如['wx-open-launch-app']
});

wx.config下面多了一项openTagList,开放标签列表,目前支持配置wx-open-launch-weappwx-open-launch-app

签名算法见JS-SDK说明文档的附录1,所有开放标签列表见文末的附录1。

步骤四:通过ready接口处理成功验证

wx.ready(function () {
  // config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中
});

步骤五:通过error接口处理失败验证

wx.error(function (res) {
  // config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,也可以在返回的res参数中查看,对于SPA可以在这里更新签名
});

小程序跳转按钮:<wx-open-launch-weapp>

用于页面中提供一个可跳转指定小程序的按钮。使用此标签后,用户需在网页内点击标签按钮方可跳转小程序。H5 通过开放标签打开小程序的场景值为 1167.
此功能的开放对象:

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

错误提示

若跳转时出现以下页面,表示网页绑定的服务号或小程序无权限,请检查是否符合上述开放对象条件。
HTML5页面打开微信小程序功能实现

注意事项( 按钮不显示、点击按钮没反应,请对照以下事项逐一排查 )

  1. username小程序原始ID
  2. path为跳转至小程序的路径,一定要加后缀.html。还能携带参数,在微信小程序中通过 onLoad的 options接收。(代码如下)
  3. <wx-open-launch-weapp>中必须用<template>标签包裹。
  4. config配置中一定要加入openTagList: ['wx-open-launch-weapp']
  5. 微信版本要求为:7.0.12及以上。 系统版本要求为:iOS 10.3及以上、Android 5.0及以上。
  6. 引入js至少是1.6以上版本。

按钮不显示,多半是wx.config配置不正确。
正确配置如下:

完整代码

<!doctype html>
<html>
<head>
    <meta charset="UTF-8">
    <title></title>
    <meta content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0" name="viewport" />
    <meta content="yes" name="apple-mobile-web-app-capable">
    <meta content="black" name="apple-mobile-web-app-status-bar-style">
    <meta content="telephone=no" name="format-detection">
    <meta content="yes" name="apple-touch-fullscreen">
    <script src="http://res.wx.qq.com/open/js/jweixin-1.6.0.js"></script> 
</head>
<body>
	<wx-open-launch-weapp id="launch-btn" username="gh_666666666666" path="/pages/index/index.html?myid=123aaa">
	    <template>
	        <style>
	            .btn {
	                padding: 12px;
	                width: 200px;
	                height: 50px;
	            }
	        </style>
	        <button class="btn">打开</button>
	    </template>
	</wx-open-launch-weapp>
	<script type="text/javascript">
		wx.config({    
			debug:false, // 是否开启调试模式
			appId:'', // 必填,公众号的唯一标识    
			timestamp: , // 必填,生成签名的时间戳
			nonceStr: '', // 必填,生成签名的随机串
			signature: '',// 必填,签名
			jsApiList:['openLocation'], // 必填,需要使用的JS接口列表
			openTagList: ['wx-open-launch-weapp'] // 可选,需要使用的开放标签列表,例如['wx-open-launch-app']
		}); 
		
		wx.ready(function () {
		  // config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中
		});
		
		wx.error(function (res) {
		  // config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,也可以在返回的res参数中查看,对于SPA可以在这里更新签名
		});
		
		var btn = document.getElementById('launch-btn');
	    btn.addEventListener('launch', function (e) {
	    	console.log('success');
	    });
	    btn.addEventListener('error', function (e) {
	    	console.log('fail', e.detail);
	    });
	</script>
</body>
</html>

在小程序端接收参数

onLoad: function (options) {   
	let myid = options.myid || '';
	util.alterDialog('提示myid', myid, '确定', null);
}

HTML5页面打开微信小程序功能实现

其他

App跳转小程序按钮:<wx-open-launch-app>

详见官方文档

到此这篇关于HTML5页面打开微信小程序的文章就介绍到这了,更多相关h5微信小程序内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

 
HTML / CSS 相关文章推荐
多重CSS背景动画实现方法示例
Apr 04 HTML / CSS
实例教程 一款纯css3实现的数字统计游戏
Nov 10 HTML / CSS
CSS3的first-child选择器实战攻略
Apr 28 HTML / CSS
CSS3+HTML5+JS 实现一个块的收缩与展开动画效果
Nov 17 HTML / CSS
基于HTML5 audio元素播放声音jQuery小插件
May 11 HTML / CSS
html5小技巧之通过document.head获取head元素
Jun 04 HTML / CSS
使用分层画布来优化HTML5渲染的教程
May 08 HTML / CSS
canvas线条的属性详解
Mar 27 HTML / CSS
HTML5拍照和摄像机功能实战详解
Jan 24 HTML / CSS
Html5 Canvas实现图片标记、缩放、移动和保存历史状态功能 (附转换公式)
Mar 18 HTML / CSS
Html5页面上如何禁止手机虚拟键盘弹出
Mar 19 HTML / CSS
flex布局中使用flex-wrap实现换行的项目实践
Jun 21 HTML / CSS
CSS元素定位之通过元素的标签或者元素的id、class属性定位详解
Sep 23 #HTML / CSS
微信小程序纯CSS实现无限弹幕滚动效果
Sep 23 #HTML / CSS
使用 CSS 构建强大且酷炫的粒子动画效果
详解CSS中postion和opacity及cursor的特性
Aug 14 #HTML / CSS
html网页引入svg图片的4种方式
HTML静态页面获取url参数和UserAgent的实现
Aug 05 #HTML / CSS
CSS使用Flex和Grid布局实现3D骰子
Aug 05 #HTML / CSS
You might like
PHP数据库操作四:mongodb用法分析
2017/08/16 PHP
通过js脚本复制网页上的一个表格的不错实现方法
2006/12/29 Javascript
Ajax,UTF-8还是GB2312 eval 还是execScript
2008/11/13 Javascript
JS代码放在head和body中的区别分析
2011/12/01 Javascript
node.js中的events.emitter.once方法使用说明
2014/12/10 Javascript
全系IE支持Bootstrap的解决方法
2015/10/19 Javascript
JS+CSS实现的经典圆角下拉菜单效果代码
2015/10/21 Javascript
javascript针对不确定函数的执行方法
2015/12/16 Javascript
Javascript 对cookie操作详解及实例
2016/12/29 Javascript
Vue.js 插件开发详解
2017/03/29 Javascript
基于jQuery实现图片推拉门动画效果的两种方法
2017/08/26 jQuery
详解使用vscode+es6写nodejs服务端调试配置
2017/09/21 NodeJs
vue非父子组件通信问题及解决方法
2018/06/11 Javascript
Angularjs中的$apply及优化使用详解
2018/07/02 Javascript
jquery 动态遍历select 赋值的实例
2018/09/12 jQuery
20多个小事例带你重温ES10新特性(小结)
2019/09/29 Javascript
[23:21]Ti4 冒泡赛第二轮DK vs C9 2
2014/07/14 DOTA
python 中文字符串的处理实现代码
2009/10/25 Python
kNN算法python实现和简单数字识别的方法
2014/11/18 Python
python在windows和linux下获得本机本地ip地址方法小结
2015/03/20 Python
python实现爬取百度图片的方法示例
2019/07/06 Python
python 多进程和协程配合使用写入数据
2020/10/30 Python
html5 实现客户端验证上传文件的大小(简单实例)
2016/05/15 HTML / CSS
Lampegiganten丹麦:欧洲领先的照明网上商店
2018/04/25 全球购物
Harrods美国:英国最大的百货公司
2018/11/04 全球购物
Myprotein台湾官方网站:全球领先的运动营养品牌
2018/12/10 全球购物
亚马逊巴西站:Amazon.com.br
2019/09/22 全球购物
经理职责范文
2013/11/08 职场文书
致长跑运动员加油稿
2014/02/20 职场文书
党员一帮一活动总结
2014/07/08 职场文书
机械制造专业大学生自我鉴定
2014/09/19 职场文书
大四优秀党员个人民主评议
2014/09/19 职场文书
雨雪天气温馨提示
2015/07/15 职场文书
素质教育学习心得体会
2016/01/19 职场文书
python3实现无权最短路径的方法
2021/05/12 Python
使用canvas仿Echarts实现金字塔图的实例代码
2021/11/11 HTML / CSS