Html5页面在微信端的分享的实现方法


Posted in HTML / CSS onAugust 30, 2018

微信分享,咋一看好像很复杂,实则非常简单。只需要调用微信官方出的微信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无效。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
CSS3 创建网页动画实现弹跳球动效果
Oct 30 HTML / CSS
css3实现动画的三种方式
Aug 24 HTML / CSS
HTML5的文档结构和新增标签完全解析
Apr 21 HTML / CSS
HTML5 video视频字幕的使用和制作方法
May 03 HTML / CSS
HTML5 与 XHTML2
Oct 17 HTML / CSS
html5 application cache遇到的严重问题
Dec 26 HTML / CSS
HTML5语音识别标签写法附图
Nov 18 HTML / CSS
详解HTML5 Canvas绘制时指定颜色与透明度的方法
Mar 25 HTML / CSS
HTML5中原生的右键菜单创建方法
Jun 28 HTML / CSS
配置H5的滚动条样式的示例代码
Mar 09 HTML / CSS
canvas简易绘图的实现(海绵宝宝篇)
Jul 04 HTML / CSS
HTML中实现音乐或视频自动播放案例详解
May 30 HTML / CSS
canvas粒子动画背景的实现示例
Sep 03 #HTML / CSS
html5中去掉input type date默认样式的方法
Sep 06 #HTML / CSS
html5新特性与用法大全
Sep 13 #HTML / CSS
HTML5新控件之日期和时间选择输入的实现代码
Sep 13 #HTML / CSS
Html5中的桌面通知Notification的实现
Sep 25 #HTML / CSS
详解canvas drawImage()方法绘制图片不显示的问题
Oct 08 #HTML / CSS
HTML5 和小程序实现拍照图片旋转、压缩和上传功能
Oct 08 #HTML / CSS
You might like
火影忍者:这才是千手柱间和扉间的真正死因,角都就比较搞笑了!
2020/03/10 日漫
php中使用Imagick实现图像直方图的实现代码
2011/08/30 PHP
PHP5.4中json_encode中文转码的变化小结
2013/01/30 PHP
深入Memcache的Session数据的多服务器共享详解
2013/06/13 PHP
基于php中使用excel的简单介绍
2013/08/02 PHP
JavaScript的目的分析
2007/01/05 Javascript
高性能JavaScript DOM编程(1)
2015/08/11 Javascript
在其他地方你学不到的jQuery小贴士和技巧(欢迎收藏)
2016/01/20 Javascript
js实现动态创建的元素绑定事件
2016/07/19 Javascript
jQuery的图片轮播插件PgwSlideshow使用详解
2016/08/11 Javascript
详解vue-cli + webpack 多页面实例应用
2017/04/25 Javascript
微信小程序分享功能之按钮button 边框隐藏和点击隐藏
2018/06/14 Javascript
在vue中安装使用vux的教程详解
2018/09/16 Javascript
关于自定义Egg.js的请求级别日志详解
2018/12/12 Javascript
javascript实现小型区块链功能
2019/04/03 Javascript
记录vue做微信自定义分享的一些问题
2019/09/12 Javascript
vue实现全匹配搜索列表内容
2019/09/26 Javascript
layui 解决form表单点击无反应的问题
2019/10/25 Javascript
详解JSON.stringify()的5个秘密特性
2020/05/26 Javascript
python如何实现excel数据添加到mongodb
2015/07/30 Python
python实现百万答题自动百度搜索答案
2018/01/16 Python
Python3字符串encode与decode的讲解
2019/04/02 Python
Pycharm连接gitlab实现过程图解
2020/09/01 Python
10分钟理解CSS3 FlexBox弹性布局
2018/12/20 HTML / CSS
Sperry官网:帆船鞋创始品牌
2016/09/07 全球购物
自主招生自荐信范文
2013/12/04 职场文书
小学校园之星事迹材料
2014/05/16 职场文书
2014各大专业毕业生自我评价
2014/09/17 职场文书
婚内分居协议书范文
2014/11/26 职场文书
2014幼儿园卫生保健工作总结
2014/12/05 职场文书
毕业生就业推荐表自我评价
2015/03/02 职场文书
2015年物业管理工作总结
2015/04/23 职场文书
2015年乡镇科普工作总结
2015/05/13 职场文书
2016父亲节感恩话语
2015/12/09 职场文书
Python 如何将integer转化为罗马数(3999以内)
2021/06/05 Python
Nginx报错104:Connection reset by peer问题的解决及分析
2022/07/23 Servers