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闪亮进度条效果实现思路及代码
Apr 17 HTML / CSS
利用CSS3的特性改变文本选中时的颜色
Sep 11 HTML / CSS
css3圆角边框和边框阴影示例
May 05 HTML / CSS
HTML5使用Audio标签实现歌词同步的效果
Mar 17 HTML / CSS
webapp字号大小跟随系统字号大小缩放的示例代码
Dec 26 HTML / CSS
关于HTML5你必须知道的28个新特性,新技巧以及新技术
May 28 HTML / CSS
浅谈移动端网页图片预加载方案
Nov 05 HTML / CSS
详解canvas绘制网络字体几种方法
Aug 27 HTML / CSS
H5离线存储Manifest原理及使用
Apr 28 HTML / CSS
css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效
Apr 29 HTML / CSS
css实现左上角飘带效果的完整代码
Mar 18 HTML / CSS
Li list-style-image 图片垂直居中实现方法
May 21 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
DC动画很好看?新作烂得令人发指,名叫《红色之子》
2020/04/09 欧美动漫
PHP通过加锁实现并发情况下抢码功能
2016/08/10 PHP
CentOS7.0下安装PHP5.6.30服务的教程详解
2018/09/29 PHP
PHP商品秒杀问题解决方案实例详解【mysql与redis】
2019/07/22 PHP
一个js控制的导航菜单实例代码
2013/12/03 Javascript
Jquery validation remote 验证的缓存问题解决方法
2014/03/25 Javascript
JavaScript及jquey实现多个数组的合并操作
2014/09/06 Javascript
JQuery中使用.each()遍历元素学习笔记
2014/11/08 Javascript
JS实现判断碰撞的方法
2015/02/11 Javascript
自制微信公众号一键排版工具
2016/09/22 Javascript
Angular4学习笔记之实现绑定和分包
2017/08/01 Javascript
laydate日历控件使用方法详解
2017/11/20 Javascript
vue中设置、获取、删除cookie的方法
2018/09/21 Javascript
ExtJs使用自定义插件动态保存表头配置(隐藏或显示)
2018/09/25 Javascript
JQuery实现ajax请求的示例和注意事项
2018/12/10 jQuery
three.js欧拉角和四元数的使用方法
2020/07/26 Javascript
js实现移动端轮播图滑动切换
2020/12/21 Javascript
[12:29]2018国际邀请赛 开幕秀
2018/08/22 DOTA
Python中使用中文的方法
2011/02/19 Python
详细介绍Python中的偏函数
2015/04/27 Python
Python操作串口的方法
2015/06/17 Python
Python实现随机生成有效手机号码及身份证功能示例
2017/06/05 Python
python学习开发mock接口
2019/04/28 Python
Django REST Framework之频率限制的使用
2019/09/29 Python
python zip()函数使用方法解析
2019/10/31 Python
解决python中的幂函数、指数函数问题
2019/11/25 Python
在Keras中CNN联合LSTM进行分类实例
2020/06/29 Python
Shell如何接收变量输入
2016/08/06 面试题
上课说话检讨书大全
2014/01/22 职场文书
咖啡蛋糕店创业计划书
2014/01/28 职场文书
研修第一天随笔感言
2014/02/15 职场文书
群教班子对照检查材料
2014/08/26 职场文书
大学毕业典礼演讲稿
2014/09/09 职场文书
入党转正申请报告
2015/05/15 职场文书
python实现黄金分割法的示例代码
2021/04/28 Python
MySQL派生表联表查询实战过程
2022/03/20 MySQL