时间:2021-05-08
微信分享,咋一看好像很复杂,实则非常简单。只需要调用微信官方出的微信jssdk,加上些许配置,就可以实现h5页面在微信上的分享,官方文档地址为:https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421141115
一、获取基本信息
找到已有公众号的appid,根据这个appid和url向后端发起请求,拿到配置所需要的参数:timestamp、noncestr和signature。
二、实现
1、页面引入JS-SDK文件
通过script标签,引入微信官网的JS-SDK文件
<script src="https://res.wx.qq.com/open/js/jweixin-1.2.0.js" type="text/javascript"></script>2、基本配置
wx.config({ debug: false, // 是否开启调试模式 appId: appid, //appid timestamp: timestamp, // 时间戳 nonceStr: noncestr, // 随机字符串 signature: signature, // 签名 jsApiList: [ 'onMenuShareTimeline', 'onMenuShareAppMessage', 'onMenuShareQQ', 'onMenuShareWeibo', 'onMenuShareQZone' ] // 需要使用的JS接口列表})3、使用
wx.ready(function(){ // 分享给好友 wx.onMenuShareAppMessage({ title: title, // 分享标题 desc: desc, // 分享描述 link: link, // 分享链接 imgUrl: imgUrl, // 分享图标 success: function () { doShareDone() }, cancel: function () { doShareCancel() } }) // 分享到朋友圈 wx.onMenuShareTimeline({ title: title, // 分享标题 link: link, // 分享链接 imgUrl: imgUrl, // 分享图标 success: function () { doShareDone() }, cancel: function () { doShareCancel() } })})// 分享成功回调function doShareDone () { console.log('分享成功')}// 取消分享回调function doShareCancel () { console.log('取消了分享')}三、调试
wx.config里的debug字段设置为true时,就可以进行调试。
调试要用到微信开发者工具,选择公众号网页项目,输入页面地址就可以了。
四、遇到的问题及解决方案
微信JS-SDK说明文档的附录5里有大部分问题的解决方案,在这里我列出我遇到的几个上面没有给出解决方案的。
1、Uncaught TypeError: Cannot read property 'config' of undefined
解决:html页面单独引入了sdk,并且组件统一也引入了一遍sdk,导致问题,删除其中之一。
2、Uncaught (in promise) TypeError: Cannot read property 'ready' of undefined
解决:同问题1。
3、invalid signature
解决:如果文档里的方法都没有解决这个问题,还有一种方法,先设置一种最基础的配置,使其config ok,然后再设置一遍自己需要的有各种参数的分享文案,这样能绕过配置,成功分享。说的可能有点拗口,简单点理解就是,页面只要有一个config成功的配置,就可以再继续配置其它分享,哪怕这个分享配置的signature无效。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
H5页面的融媒体平台。在微网页设计中,HTML5页面是其重要开发内容,目前常用的用于设计H5页面的软件主要包括两类:(1)通过简易模板来对HTML5页面进行设计
HTML5创建canvas元素复制代码代码如下:HTML5functionpageLoaded(){alert('HTML5页面加载完毕!');}提示:你的浏览
AndroidWebView从assets中加载html5页面,实现地理位置定位,有需要的朋友可以参考下。今天调研一个html5页面的定位问题,发现在手机浏览器
Html5页面在手机端做自适配是很常见的技术需求,下面介绍下在html页面使用hotcss简介使用动态的HTML根字体大小和动态的viewportscale。遵
本文实例讲述了JS判断当前页面是否在微信浏览器打开的方法。分享给大家供大家参考,具体如下:最近做很多HTML5的项目,很多页面会通过微信微博等SNS分享出去。在