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实现带动画效果导航菜单无需js
Sep 27 HTML / CSS
CSS3 Flexbox中flex-shrink属性的用法示例介绍
Dec 30 HTML / CSS
html5+css3气泡组件的实现
Nov 21 HTML / CSS
CSS3实现可关闭的下拉手风琴菜单效果
Aug 31 HTML / CSS
CSS3制作3D立方体loading特效
Nov 09 HTML / CSS
HTML5实践-图片设置成灰度图
Nov 12 HTML / CSS
HTML5之SVG 2D入门5—颜色的表示及定义方式
Jan 30 HTML / CSS
html特殊符号示例 html特殊字符编码对照表
Jan 14 HTML / CSS
怎样实现H5+CSS3手指滑动切换图片的示例代码
May 05 HTML / CSS
用canvas显示验证码的实现
Apr 10 HTML / CSS
CSS3 实现的图片悬停的切换按钮
Apr 13 HTML / CSS
css如何把元素固定在容器底部的四种方式
Jun 16 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
解析PayPal支付接口的PHP开发方式
2010/11/28 PHP
php+mysql+jquery实现简易的检索自动补全提示功能
2017/04/15 PHP
Thinkphp5+uploadify实现的文件上传功能示例
2018/05/26 PHP
js解析与序列化json数据(二)序列化探讨
2013/02/01 Javascript
JSONP跨域的原理解析及其实现介绍
2014/03/22 Javascript
javascript常用功能汇总
2015/07/05 Javascript
jquery实现的横向二级导航效果代码
2015/08/26 Javascript
有关jquery与DOM节点操作方法和属性记录
2016/04/15 Javascript
JS延时器提示框的应用实例代码解析
2016/04/27 Javascript
JS动态给对象添加事件的简单方法
2016/07/19 Javascript
jQuery简单实现列表隐藏和显示效果示例
2016/09/12 Javascript
javascript 判断页面访问方式电脑或者移动端
2016/09/19 Javascript
js通过指定下标或指定元素进行删除数组的实例
2017/01/12 Javascript
vue构建单页面应用实战
2017/04/10 Javascript
jQuery设置图片等比例缩小的方法
2017/04/29 jQuery
浅谈mint-ui 填坑之路
2017/11/06 Javascript
js实现以最简单的方式将数组元素添加到对象中的方法
2017/12/20 Javascript
Vue.js 十五分钟入门图文教程
2018/09/12 Javascript
解决v-for中使用v-if或者v-bind:class失效的问题
2018/09/25 Javascript
element-ui带输入建议的input框踩坑(输入建议空白以及会闪出上一次的输入建议问题)
2019/01/15 Javascript
js实现延迟加载的几种方法详解
2019/01/19 Javascript
ant design 日期格式化的实现
2020/10/27 Javascript
vue3中轻松实现switch功能组件的全过程
2021/01/07 Vue.js
python 按照固定长度分割字符串的方法小结
2018/04/30 Python
详解python中的生成器、迭代器、闭包、装饰器
2019/08/22 Python
django实现类似触发器的功能
2019/11/15 Python
用canvas实现图片滤镜效果附演示
2013/11/05 HTML / CSS
北美最大的参茸药食商城:德成行
2020/12/06 全球购物
strlen的几种不同实现方法
2013/05/31 面试题
SQL Server的固定数据库角色都有哪些?对应的服务器权限有哪些?
2013/05/18 面试题
《世界多美呀》教学反思
2014/03/02 职场文书
中学生学雷锋活动心得体会
2014/03/10 职场文书
报纸媒体创意广告词
2014/03/17 职场文书
浅谈JS的二进制家族
2021/05/09 Javascript
常用的文件对应的MIME类型汇总
2022/04/26 HTML / CSS
MySQL中的 inner join 和 left join的区别解析(小结果集驱动大结果集)
2023/05/08 MySQL