微信分享,咋一看好像很复杂,实则很是简单。只须要调用微信官方出的微信jssdk,加上些许配置,就能够实现h5页面在微信上的分享,官方文档地址为:javascript
https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421141115
找到已有公众号的appid,根据这个appid和url向后端发起请求,拿到配置所须要的参数:timestamp、noncestr和signature。html
经过script标签,引入微信官网的JS-SDK文件java
<script src="https://res.wx.qq.com/open/js/jweixin-1.2.0.js" type="text/javascript"></script>
1 wx.config({ 2 debug: false, // 是否开启调试模式 3 appId: appid, //appid 4 timestamp: timestamp, // 时间戳 5 nonceStr: noncestr, // 随机字符串 6 signature: signature, // 签名 7 jsApiList: [ 8 'onMenuShareTimeline', 9 'onMenuShareAppMessage', 10 'onMenuShareQQ', 11 'onMenuShareWeibo', 12 'onMenuShareQZone' 13 ] // 须要使用的JS接口列表 14 })
1 wx.ready(function(){ 2 // 分享给好友 3 wx.onMenuShareAppMessage({ 4 title: title, // 分享标题 5 desc: desc, // 分享描述 6 link: link, // 分享连接 7 imgUrl: imgUrl, // 分享图标 8 success: function () { 9 doShareDone() 10 }, 11 cancel: function () { 12 doShareCancel() 13 } 14 }) 15 16 // 分享到朋友圈 17 wx.onMenuShareTimeline({ 18 title: title, // 分享标题 19 link: link, // 分享连接 20 imgUrl: imgUrl, // 分享图标 21 success: function () { 22 doShareDone() 23 }, 24 cancel: function () { 25 doShareCancel() 26 } 27 }) 28 })
wx.config里的debug字段设置为true时,就能够进行调试。后端
调试要用到微信开发者工具,选择公众号网页项目,输入页面地址就能够了。promise
微信JS-SDK说明文档的附录5里有大部分问题的解决方案,在这里我列出我遇到的几个上面没有给出解决方案的。微信
一、Uncaught TypeError: Cannot read property 'config' of undefined
解决:html页面单独引入了sdk,而且组件统一也引入了一遍sdk,致使问题,删除其中之一。微信开发
二、Uncaught (in promise) TypeError: Cannot read property 'ready' of undefined
解决:同问题1。app
解决:若是文档里的方法都没有解决这个问题,还有一种方法,页面只要有一个config成功的配置,就能够再继续配置其它分享,哪怕这个分享配置的signature无效。工具