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实现多背景展示效果通过CSS3定位多张背景
Aug 10 HTML / CSS
用CSS3打造HTML5的Logo(实现代码)
Jun 16 HTML / CSS
Css3新特性应用之视觉效果实例
Dec 12 HTML / CSS
纯CSS3制作的鼠标悬停时边框旋转
Jan 03 HTML / CSS
简单聊聊H5的pushState与replaceState的用法
Apr 03 HTML / CSS
HTML5本地存储之Web Storage应用介绍
Jan 06 HTML / CSS
HTML5 预加载让页面得以快速呈现
Aug 13 HTML / CSS
HTML5的一个显示电池状态的API简介
Jun 18 HTML / CSS
使用phonegap获取位置信息的实现方法
Mar 31 HTML / CSS
HTML5 LocalStorage 本地存储详细概括(多图)
Aug 18 HTML / CSS
HTML5 body设置自适应全屏
May 07 HTML / CSS
css背景和边框标签实例详解
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
php+mysqli使用面向对象方式查询数据库实例
2015/01/29 PHP
ThinkPHP实现递归无级分类――代码少
2015/07/29 PHP
PHP JWT初识及其简单示例
2018/10/10 PHP
javascript 对象的定义方法
2007/01/10 Javascript
Jquery为单选框checkbox绑定单击click事件
2012/12/18 Javascript
jQuery实现随意改变div任意属性的名称和值(部分原生js实现)
2013/05/28 Javascript
js中通过父级进行查找定位元素
2014/06/15 Javascript
javascript实现列表滚动的方法
2015/07/30 Javascript
jQuery+ajax实现滚动到页面底部自动加载图文列表效果(类似图片懒加载)
2016/06/07 Javascript
微信开发 使用picker封装省市区三级联动模板
2016/10/28 Javascript
jQuery基于ajax操作json数据简单示例
2017/01/05 Javascript
socket.io学习教程之基础介绍(一)
2017/04/29 Javascript
详解使用Visual Studio Code对Node.js进行断点调试
2017/09/14 Javascript
Node.js 如何利用异步提升任务处理速度
2019/01/07 Javascript
[01:05:40]VG vs Newbee 2018国际邀请赛小组赛BO2 第二场 8.17
2018/08/20 DOTA
Python 随机生成中文验证码的实例代码
2013/03/20 Python
全面了解Python环境配置及项目建立
2016/06/30 Python
Python交互环境下实现输入代码
2018/06/22 Python
python调用摄像头显示图像的实例
2018/08/03 Python
python数据批量写入ScrolledText的优化方法
2018/10/11 Python
基于Python函数和变量名解析
2019/07/19 Python
django中使用Celery 布式任务队列过程详解
2019/07/29 Python
将pytorch转成longtensor的简单方法
2020/02/18 Python
python3 实现口罩抽签的功能
2020/03/11 Python
在Ubuntu中安装并配置Pycharm教程的实现方法
2021/01/06 Python
以特惠价提供在线奢侈品购物:FRMODA.com
2018/01/25 全球购物
Huda Beauty官方商店:化妆和美容产品
2020/09/05 全球购物
锐步香港官方网上商店:Reebok香港
2020/11/05 全球购物
什么是Smarty变量操作符?如何使用Smarty变量操作符
2014/07/18 面试题
在对linux系统分区进行格式化时需要对磁盘簇(或i节点密度)的大小进行选择,请说明选择的原则
2012/11/24 面试题
课改先进个人汇报材料
2014/01/26 职场文书
2014年大学生四年规划书范文
2014/04/03 职场文书
暑期培训班策划方案
2014/08/26 职场文书
匿名信格式范文
2015/05/27 职场文书
《称赞》教学反思
2016/02/17 职场文书
MySQL创建管理LIST分区
2022/04/13 MySQL