微信公众号跳转微信小程序,自定义微信跳转标签_opentaglist-程序员宅基地

技术标签: 微信小程序  微信  jquery  javascript  

 引入微信自带的js脚本

https://res.wx.qq.com/open/js/jweixin-1.6.0.js

配置wx.config,并且增加openTagList开放标签列表(wx-open-launch-weapp)

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

 wx-open-launch-weapp标签的使用

<wx-open-launch-weapp
		          id="launch-btn"
		          username="gh_xxxxxxxx" 
		          path="需要跳转小程序的路径"
		    >
		    <template>
		      <button class="button" style="width: 200px; height: 45px; text-align: center; font-size: 17px; display: block; margin: 0 auto; padding: 8px 24px; border: none; border-radius: 4px; background-color: #07c160; color:#fff;">跳转</button> 
		    </template>
		  </wx-open-launch-weapp>

 使用详情请参考官方文档

后端获取签名参数详情接口请参考微信开发文档附录1-JS-SDK使用权限签名算法

注意事项:

1、只能跳转发布的小程序,不能跳转体验版和开发版

2、公众号只能是认证的非个人主体的服务号,不能是订阅号

3、微信公众号中必须配置js安全域名,并且安全域名必须开放80端口,否则不能成功添加js安全域名,配置了js安全域名才能访问JS接口

4、如果不能正常获取accessToken,请在微信公众号官网配置白名单

全部前端的demo代码如下

<html>
  <head>
    <title>跳转小程序</title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1, maximum-scale=1">
    <link rel="stylesheet" href="https://res.wx.qq.com/open/libs/weui/2.4.1/weui.min.css"></link>
    <script typet="text/javascript" src="http://code.jquery.com/jquery-latest.js"></script>
    <script src="https://res.wx.qq.com/open/js/jweixin-1.6.0.js"></script>
    <style>
    </style>
  </head>
  <body>
	<!-- display: flex; align-items: center;" -->
    <div id="wechat-web-container" style="width: 100%;height: 100vh;">
    </div>
    <script type="text/javascript">
	
	
      $(document).ready(function(){
          function dff(){
            $.ajax({
              url: '后端根据获取签名的接口',
			  dataType : "jsonp",(解决跨域的问题,后端返回callback + "("+返回的json字符串+")")
			  data: {url: location.href.split('#')[0]},
              type: 'GET',
			  jsonp : "callback",
              success:function(result){
				console.info('result',result);
                wx.config({
                  debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
                  appId: '', // 必填,公众号的唯一标识
                  timestamp: result.timestamp, // 必填,生成签名的时间戳
                  nonceStr: result.noncestr, // 必填,生成签名的随机串
                  signature: result.signature,// 必填,签名
                  jsApiList: ['chooseImage', 'previewImage'], // 必填,需要使用的JS接口列表
                  openTagList: ['wx-open-launch-weapp'] // 可选,需要使用的开放标签列表
                });
            },
			 error:function(e) {
				 console.info(e)
			 }});
          }
          dff();
		  
		  //获取浏览器地址的参数
		  function getQueryVariable() {
		    let href = window.location.href
		  	console.info('href',href)
		    let query = href.substring(href.indexOf('?') + 1);
		  	console.info('query',query)
		    let vars = query.split("&");
		    let obj = {}
		    for (var i = 0; i < vars.length; i++) {
		      let pair = vars[i].split("=");
		      obj[pair[0]] = pair[1]
		    }
		    return obj;
		  }
		  var querys = getQueryVariable();
		  console.info("querys",querys)
		  var path = querys.path ? decodeURIComponent(querys.path) : 跳转小程序的路径,可以动态传参数
		  console.info("path",path)
		  var username = ''//username小程序原始id
		  //  replace username
          //给id=wechat-web-container增加标签
		  $('#wechat-web-container').append(`
		    <wx-open-launch-weapp
		          id="launch-btn"
		          username="${username}" 
		          path="${path}"
		    >
		    <template>
		      <button class="button" style="width: 200px; height: 45px; text-align: center; font-size: 17px; display: block; margin: 0 auto; padding: 8px 24px; border: none; border-radius: 4px; background-color: #07c160; color:#fff;">跳转</button> 
		    </template>
		  </wx-open-launch-weapp>`)
		  
		  // alert(path)
 
          wx.ready(function () {
              console.log('config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中')
 
              var btn = document.getElementById('launch-btn');
              btn.addEventListener('launch', function (e) {
                console.log('success');
                alert('success')
              });
              btn.addEventListener('error', function (e) {
                console.log('fail', e.detail);
                alert('fail', e.detail)
                // alert('fail', e.detail)
              });
          });
      });
    </script>
	<style>
	.button {
		position:absolute;
		left:50%;
		top:50%;
		transform: translate(-50%,-50%);
	}
	</style>
  </body>
</html>

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_45256333/article/details/127324192

智能推荐

JPA原理分析-程序员宅基地

文章浏览阅读1.8k次。零.背景和题外话工作中经常用到JPA去做CURD。出于对某事物全部或部分属性空白时,本能的想添加此事物的属性的内在心理,正好手上有在搭一个新的练手项目,于是开启了Debug分析之旅。读完这篇文章,你将从源码层面明白JPA是如何工作的。值得注意的是:**JPA是一个规范,而非像Hibernate一样是一个解决方案。**这一点在后文也将有所体现。目录零.背景和题外话一.Dao的接口分析二.调用过程分析三.完整过程总结一.Dao的接口分析这是一个基本的Dao接口。如图:重点就在JpaRep_jpa原理

嵌入式WIFI芯片通过lwip获取心知天气实时天气信息和时间信息(包含完整代码)_嵌入式wifi芯片通过lwip获取心知天气实时天气信息和时间信息(包含完整代码)-程序员宅基地

文章浏览阅读1.3k次,点赞29次,收藏21次。本文讲解了如何在嵌入式端通过LWIP TCP的方式获取天气状况,文中包含了完整的代码,适合初学者了解和使用。_嵌入式wifi芯片通过lwip获取心知天气实时天气信息和时间信息(包含完整代码)

实现Ant Design Tree组件的节点的增删改_基于 ant design vue实现tree的增删改-程序员宅基地

文章浏览阅读6k次,点赞4次,收藏33次。实现Ant Design Tree组件的节点的增删改在做项目时最近遇到一个需求,需要用到Antd中的tree,并能够实现对tree的节点的增加和删除,以及节点名称的修改。去翻Antd官网文档,发现tree组件并没有提供关于节点操作的api,但是有鼠标右击的api。借助这个鼠标右击,以及其他组件是可以实现对节点的增删改。下面进行截图介绍:截图介绍第一部分:Tree组件最外层节点只能增加子节点父节点可以增加子节点,修改自己的节点名称,删除节点3.最内层节点不允许再添加子节点,只允许修改自己的_基于 ant design vue实现tree的增删改

vue基于elementui实现的带搜索功能的懒加载树_element ui树结构懒加载如何搜索-程序员宅基地

文章浏览阅读4.1k次,点赞4次,收藏20次。基于elementui实现的带搜索功能的懒加载树1. 思路elementui的el-tree本身可以实现懒加载功能,但是却不能进行远程搜索,思路就是使用两颗树,一颗用来懒加载,另一颗用来全部加载。2.实现方式1.创建一个自定义组件j-tree2.画页面:一个el-input,两个el-tree<template> <div class="treebox"> <h2>{{title}}</h2> <el-_element ui树结构懒加载如何搜索

innovus停止当前命令_Innovus 小技巧 | Innovus 中如何验证低功耗设计-程序员宅基地

文章浏览阅读1.4k次。此处论及的低功耗设计是指带IEEE1801 或CPF 的设计,即有多个电压域的设计,对于这样的设计,power mesh 跟placement 做完后,通常需要检查:placement 是否遵照了power intent 的需求,把对应的cell 摆放在了对应的电压域中;如何report 某个instance 或某个 power domain 的低功耗信息;如何对Power Grid 进行chec..._low power innovus

Linux数据恢复-程序员宅基地

文章浏览阅读543次,点赞11次,收藏11次。严格来讲,Linux这个词本身只表示Linux内核,但实际上人们已经习惯了用Linux来形容整个基于 Linux内核,并且使用GNU 工程各种工具和数据库的操作系统。Ext3/Ext4 是日志式文件系统,他们是前者的扩展,保持了对于前者的兼容性,并且带来了较高的安全特性。与Ext2不同的是,Ext3/Ext4文件系统下,当文件删 除后,系统会清除文件相应的i-节点,这样做的优点在于通过unclean载入文件系统后,重放日志时,可以减少对文件系统的访问次数,但这同样增加了数 据恢复难度。

随便推点

MyBatis-程序员宅基地

文章浏览阅读245次。MyBatis是一个java数据持久层框架,通过将sql语句与java对象的映射配置在xml文件中,实现了简化数据库操作的功能,使得开发者更方便的对数据库进行操作.当执行相同查询时,mybatis会将查询结果缓存到内存中,下次查询时,会直接上缓存中获取数据,而不会去数据库中执行查询操作。mybatis本地缓存是默认开启的,指在同一个sqlSession中,对相同的查询进行缓存。${}是字符串替换的方式在sql语句中,{}会直接替换成参数的值,不会进行预编译处理。${}和#{}都是用来传参的。

python中turtle怎么画万花筒,python中turtle怎么画半圆-程序员宅基地

文章浏览阅读623次,点赞14次,收藏18次。大家好,本文将围绕用python的turtle画炫酷的图展开说明,python中turtle怎么画万花筒是一个很多人都想弄明白的事情,想搞清楚python中turtle怎么画半圆需要先了解以下几个事情。

如何使用python备份mysql数据库_python 执行备份mysql动作-程序员宅基地

文章浏览阅读290次。这个脚本将每小时备份指定的MySQL表,并将备份文件存储在指定的目录中。你可以根据需要调整备份频率、数据库信息和备份文件的存储路径。要实现这个功能,你可以使用Python的定时任务库(如APScheduler)和MySQL的备份工具(如mysqldump)。_python 执行备份mysql动作

service.bat install/remove [service_name [--rename]] [--user username]_usage: service.bat install/remove [service_name [--程序员宅基地

文章浏览阅读1k次。service.bat install/remove [service_name [--rename]] [--user username]运行Tomcat一闪而过报错为: service.bat install/remove [service_name [--rename]] [--user username]Tomcat环境变量设置运行Tomcat一闪而过查询原因:右键tomcat的bin目录下startup.bat找一个文本编辑器打开,然后在文本的最后敲上pause,保存后重新运行startup_usage: service.bat install/remove [service_name [--rename]] [--user username

基于Lottie的动态锁屏APP_lottie拉伸更换文字-程序员宅基地

文章浏览阅读215次。实习期间做的一个项目,项目主要功能是提供动态锁屏壁纸,并实现手势交互,增加可玩性。壁纸资源基于Lottie动画,项目还实现了可以从手机资源库中读取Lottie的json文件,可以从网上下载Lottie资源的json文件,从而可设为手机的锁屏。_lottie拉伸更换文字

python:functools --- 高阶函数和可调用对象上的操作_functools模块在python3.8中还能用吗?-程序员宅基地

文章浏览阅读170次。python:functools --- 高阶函数和可调用对象上的操作_functools模块在python3.8中还能用吗?