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特性绘制简易版围棋效果
Sep 28 HTML / CSS
CSS3实现任意图片lowpoly动画效果实例
May 11 HTML / CSS
button在IE6/7下的黑边去除方案
Dec 24 HTML / CSS
纯CSS和jQuery实现的在页面顶部显示的进度条效果2例(仿手机浏览器进度条效果)
Apr 16 HTML / CSS
利用css3如何设置没有上下边的列表间隔线
Jul 03 HTML / CSS
通过一张图教会你CSS3倒影的实现
Sep 26 HTML / CSS
纯HTML5+CSS3制作生日蛋糕代码
Nov 16 HTML / CSS
HTML5的video标签的浏览器兼容性增强方案分享
May 19 HTML / CSS
html5 canvas绘制矩形和圆形的实例代码
Jun 16 HTML / CSS
HTML5之消息通知的使用(Web Notification)
Oct 30 HTML / CSS
CSS3 天气图标动画效果
Apr 06 HTML / CSS
css display table 自适应高度、宽度问题的解决
May 07 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
短波问题解答
2021/02/28 无线电
oracle资料库函式库
2006/10/09 PHP
php更改目录及子目录下所有的文件后缀的代码
2010/09/24 PHP
如何使用Linux的Crontab定时执行PHP脚本的方法
2011/12/19 PHP
php foreach循环中使用引用的问题
2013/11/06 PHP
PHP中使用register_shutdown_function函数截获fatal error示例
2015/04/21 PHP
PHP中使用GD库绘制折线图 折线统计图的绘制方法
2015/11/09 PHP
PHP模板引擎Smarty之配置文件在模板变量中的使用方法示例
2016/04/11 PHP
php+javascript实现的动态显示服务器运行程序进度条功能示例
2017/08/07 PHP
JS 字符串连接[性能比较]
2009/05/10 Javascript
jQuery find和children方法使用
2011/01/31 Javascript
正则表达式中特殊符号及正则表达式的几种方法总结(replace,test,search)
2013/11/26 Javascript
js验证电话号码与手机支持+86的正则表达式
2014/01/23 Javascript
原生JS绑定滑轮滚动事件兼容常见浏览器
2014/06/30 Javascript
JavaScript bold方法入门实例(把指定文字显示为粗体)
2014/10/17 Javascript
Node.js实现文件上传
2016/07/05 Javascript
JavaScript的setter与getter方法
2017/11/29 Javascript
使用layui日期控件laydate对开始和结束时间进行联动控制的方法
2019/09/06 Javascript
JavaScript实现轮播图特效
2020/04/10 Javascript
解决Vue watch里调用方法的坑
2020/11/07 Javascript
python使用PIL缩放网络图片并保存的方法
2015/04/24 Python
详解python中 os._exit() 和 sys.exit(), exit(0)和exit(1) 的用法和区别
2017/06/23 Python
pandas 实现字典转换成DataFrame的方法
2018/07/04 Python
Python使用win32com模块实现数据库表结构自动生成word表格的方法
2018/07/17 Python
Python 访问限制 private public的详细介绍
2018/10/16 Python
django使用haystack调用Elasticsearch实现索引搜索
2019/07/24 Python
django项目登录中使用图片验证码的实现方法
2019/08/15 Python
Python完全识别验证码自动登录实例详解
2019/11/24 Python
pyftplib中文乱码问题解决方案
2020/01/11 Python
html2canvas生成的图片偏移不完整的解决方法
2020/05/19 HTML / CSS
舒适的豪华鞋:Taryn Rose
2018/05/03 全球购物
微软马来西亚官方网站:Microsoft马来西亚
2019/11/22 全球购物
法人授权委托书范本
2014/04/04 职场文书
建筑施工安全责任书
2014/07/24 职场文书
小学生感恩父母演讲稿
2014/08/28 职场文书
天河观后感
2015/06/11 职场文书