网页跳转小程序需要使用微信的开放标签 wx-open-launch-weapp ,使用开放标签需要使用微信的jssdk,然后sdk的版本不能低,低版本点击无效。

先给官方文档的链接 点击跳转

建议认真看完,这个坑有点多

1.必须有插槽的代码,以下二选一,不用会报错,并且设置不了样式,样式需要在插槽里面设置

username 是你的小程序原始ID,需要替换成你的

         <view class="pb2"><image class="pb2Img" @click="navBtn" :src="pb2" mode="widthFix"></image><view  :style="{ position: 'absolute',  top: 0, left: 0, width: '100%',zIndex:2, height: '100%' }" v-if="isOk"><wx-open-launch-weapp id="launch-btn" username="gh_8f01eb0"path="pages/startUp/startUp?pageUrl=pubPage" :style="{ position: 'absolute',zIndex:2, top: 0, left: 0, width: '100%', height: '100%' }"><script type="text/wxtag-template"><div style="position: absolute;z-idnex:999; top: 0, left: 0;bottom:0;right:0;width: 100%;height: 100%;" /></script></wx-open-launch-weapp></view></view>
.pb2 {position: fixed;bottom: 64rpx;left: 58vw;width: 230rpx;height: 84rpx;margin-left: -100rpx;z-index: 2;}.pb2Img {width: 100%;height: 100%;position: absolute;z-index: 1;left: 0;top: 0;}

效果图:点击进入的按钮是 pb2Img 图片,wx-open-launch-weapp占满图片的位置

2.必须确保jssdk ready ,并且在config里面设置了 openTagList:['wx-open-launch-weapp'] ,没设置会点击无效

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

3.sdk的版本不能低,低版本点击无效,导入jssdk包

npm install jweixin-module --save 

使用:

let jweixin = require('jweixin-module')
Vue.prototype.$wx = jweixin

4.一定要配置JS接口安全域名,只有在配置的JS接口安全域名访问,才能跳转小程序

开放标签开放对象

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

实现网页跳转小程序的操作步骤:

使用步骤

微信开放标签使用步骤与微信JS-SDK类似,也需要引入JS文件等步骤。如果是公众号身份的网页,需要绑定安全域名,如果是使用小程序云开发静态网站托管的小程序网页,则不需绑定安全域名即可直接使用(即跳过下面"步骤一:绑定安全域名")。

1. 绑定域名

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

2. 引入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 标准模块加载方法加载。

3. 通过config接口注入权限验证配置并申请所需开放标签

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

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

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

4. 通过ready接口处理成功验证

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

5. 通过error接口处理失败验证

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

使用说明

所有开放标签都能像普通的HTML标签一样在页面中直接使用,不需要再进行额外的处理。

如果所使用的标签允许提供插槽,由于插槽中模版的样式是和页面隔离的,因此需要注意在插槽中定义模版的样式。插槽模版及样式均需要通过<template></template>进行包裹。对于Vue等视图框架,为了避免template标签冲突的问题,可使用<script type="text/wxtag-template"></script>进行代替,来包裹插槽模版和样式。另外,对于具名插槽还需要通过slot属性声明插槽名称,下文标签插槽中的default插槽为默认插槽,可不声明插槽名称。

对于标签事件,均可通过event.detail获得详细信息。如果无特殊说明,下文标签事件说明中的返回值均指代event.detail中的内容。

另外,需要注意以下几点:

  1. 页面中与布局和定位相关的样式,如position: fixed; top -100;等,尽量不要写在插槽模版的节点中,请声明在标签或其父节点上;
  2. 对于有CSP要求的页面,需要添加白名单frame-src https://*.qq.com webcompt:,才能在页面中正常使用开放标签。

H5跳转小程序,uniapp跳转小程序相关推荐

  1. 微信小程序uniapp框架配置小程序分包

    分包可以减少小程序首次启动的加载时间: 我们在项目中,把tabbar相关的4个页面放到主包中,其他的页面放在分包中 1.在项目的根目录中,创建分包的根目录,名为subpkg 2.在page.json中 ...

  2. h5跳转微信公众号文章,小程序,任意站跳转链接制作方法?

    什么是url scheme? URL scheme是系统提供的一种机制,它可以由应用程序注册,然后其他程序通过url scheme来调用该应用程序. 它分为两部分:一部分是系统默认的url schem ...

  3. 小程序如何跳转到第三方H5页面

    小程序如何跳转到第三方H5页面 需求: 用户提供了他们的H5地址,希望在我们的小程序平台上开个口子,能够直接跳转到他们的H5页面 问题: 我们的小程序其实是一个壳,所有的业务都写在H5页面中,然后通过 ...

  4. uniapp开发微信小程序-4.页面跳转与横向滑动

    uniapp开发微信小程序-4.页面跳转与横向滑动 本篇文章主要是想记录一下横向滑动功能,备忘的同时给大家做个分享. 但既然是初级分享系列文章,为了方便新手朋友的上手工作,还是在此之前说一下页面跳转的 ...

  5. uniapp生成小程序码仿商品小程序码跳转到商品详情

    uniapp生成小程序码仿商品小程序码跳转到商品详情 之前在网上找了下没有相关教程去生成小程序商品小程序码微信扫码直接跳转到小程序详情页面,今天我们就用uniapp来实现这个,其实微信小程序端方法大致 ...

  6. 微信小程序 uniapp 使用navigateTo跳转url传递对象

    微信小程序 使用navigateTo跳转url传递对象 阐述 在使用 "uni.navigateTo" 跳转的时候,如果要不是对象的方式传递,则会在url上面拼接太多的参数了.不易 ...

  7. uniApp配置微信分享 uniApp跳转微信小程序

    最近在做uniApp时需要跳转微信小程序进行支付,以为和跳转支付宝小程序支付一样简单结果让我发狂,跳转微信代码其实很简单就是下面这一段,但是要配置一大推东西 提示:plus为App端默认的系统参数,不 ...

  8. vue3引入JS-SDK实现h5分享小卡片、跳转微信小程序功能

    微信js-sdk官方文档: https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/JS-SDK.html 一.实现h5分享小卡片 想 ...

  9. uni-app以及微信小程序页面跳转后实现页面自动刷新

    uni-app以及微信小程序页面跳转后实现页面自动刷新 在程序中需要从一个switch TAb页面跳转到另一个switch Tab页面,但是页面跳转之后,发现添转后的页面不会执行onload里面的刷新 ...

  10. uni-app微信小程序uni.navigateTo跳转无效问题;记录一次uni-app页面跳转无效,来回跳转问题;wx.navigateTo ,跳转超过10次怎么点不动的解决办法。

    场景需求:从小程序A页面跳转到小程序B页面,然后B页面还可以跳到A页面. 跳转失效原因: –1.uni.navigateTo只能跳转到非tabBar页面,tabBar导航栏页面只能用uni.switc ...

最新文章

  1. python的运行窗口-Python初学——窗口视窗Tkinter
  2. Vue.js(17)之 插槽
  3. IdentityServer4-前后端分离之Vue
  4. 和套套一样,一次性橡胶手套制作现场, 这鬼畜的画风
  5. redis相对于mysql有什么劣势
  6. python selenium右键另存为_手把手教你系列练习篇之1python+ selenium自动化测试(详细教程)...
  7. MAC查看CPU信息
  8. python求平方值,python – 字典的平方值
  9. ad板子挖孔_用AD软件画孔的注意了!
  10. 家居装修行业APP开发解决方案
  11. 一周肝出Linux之远程服务详解(ssh远程登录、scp远程复制、sftp安全下载、TCP Wrappers访问控制)
  12. MOSS SDK学习(5)
  13. 构造器是什么?构造器有什么用?
  14. 利用python和Tushare自动更新A股每日数据
  15. 多元矩阵乘积的导数问题
  16. skylake服务器CPU型号芯片,Skylake与Kaby Lake顶级处理器到底有多大差别?Intel i7-7700K评测...
  17. 解决ios设备自带邮箱只能接收邮件不能发送邮件问题的方法
  18. 区块链软件开发公司谈分布式账本与区块链账本的区别
  19. Charles切环境,使用map Local
  20. 微型计算机原理经典,微机原理经典课后作业考试必考

热门文章

  1. js 封装ajax方法吗,原生JS封装ajax方法
  2. Postgresql关于Vacuum的作用和操作方法,Vacuum full类似alter table会锁表并生成新的relfilenode
  3. 预防培训班害人和架构介绍(理论)
  4. pes2019手游服务器维护,【实况手游】解读PES2019手游未来的更新内容!
  5. 20MS/s、40MS/s、80MS/s、125MS/s采样率的采集卡选择与应用
  6. td是什么意思php,td是什么意思
  7. 【补坑】Java自动装箱的原因
  8. oracle 注册程序,Oracle 12c New Feature: Listener注册进程LREG
  9. nginx配置文件简介
  10. win10重置进度条不动了_小编教你win10系统更新进度条不动了的恢复教程