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 Backgrounds属性相关介绍
May 11 HTML / CSS
纯CSS3实现扇形动画菜单(简化版)实例源码
Jan 17 HTML / CSS
CSS3实现王者匹配时的粒子动画效果
Apr 12 HTML / CSS
分享一个页面平滑滚动小技巧(推荐)
Oct 23 HTML / CSS
Javascript 高级手势使用介绍
Apr 21 HTML / CSS
html5中的一些标签学习(心得)
Oct 18 HTML / CSS
HTML5打开手机扫码功能及优缺点
Nov 27 HTML / CSS
HTML5 WebSocket实现点对点聊天的示例代码
Jan 31 HTML / CSS
Html5调用手机摄像头并实现人脸识别的实现
Dec 21 HTML / CSS
HTML文本属性&amp;颜色控制属性的实现
Dec 17 HTML / CSS
详解如何将 Canvas 绘制过程转为视频
Jan 25 HTML / CSS
html5+实现plus.io进行拍照和图片等获取
Jun 01 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的文件操作与算法实现的面试题示例
2015/08/10 PHP
WordPress中获取指定分类及其子分类下的文章数目
2015/12/31 PHP
PHP数组相加操作及与array_merge的区别浅析
2016/11/26 PHP
PHP 计算两个时间段之间交集的天数示例
2019/10/24 PHP
javascript instanceof,typeof的区别
2010/03/24 Javascript
JavaScript 布尔操作符解析  &amp;&amp; || !
2012/08/10 Javascript
JQuery onload、ready概念介绍及使用方法
2013/04/27 Javascript
JavaScript:new 一个函数和直接调用函数的区别分析
2013/07/10 Javascript
jquery向上向下取整适合分页查询
2014/09/06 Javascript
JavaScript学习笔记之JS函数
2015/01/22 Javascript
详解JavaScript中的forEach()方法的使用
2015/06/08 Javascript
jquery实现通用的内容渐显Tab选项卡效果
2015/09/07 Javascript
jQuery Real Person验证码插件防止表单自动提交
2015/11/06 Javascript
原生JS实现图片轮播与淡入效果的简单实例
2016/08/21 Javascript
微信小程序 选项卡的简单实例
2017/05/24 Javascript
jQuery实现 RadioButton做必选校验功能
2017/06/15 jQuery
Vue全家桶实践项目总结(推荐)
2017/11/04 Javascript
Vue组件开发技巧总结
2018/03/04 Javascript
JavaScript函数的4种调用方法实例分析
2019/03/05 Javascript
微信小程序canvas截取任意形状的实现代码
2020/01/13 Javascript
JavaScript实现简单进度条效果
2020/03/25 Javascript
Node.js API详解之 Error模块用法实例分析
2020/05/14 Javascript
vue中组件通信详解(父子组件, 爷孙组件, 兄弟组件)
2020/07/27 Javascript
Python中暂存上传图片的方法
2015/02/18 Python
Python调用adb命令实现对多台设备同时进行reboot的方法
2018/10/15 Python
如何利用python给图片添加半透明水印
2019/09/06 Python
简单介绍django提供的加密算法
2019/12/18 Python
pandas的resample重采样的使用
2020/04/24 Python
美国批发零售网站:GearXS
2016/07/26 全球购物
澳大利亚的奢侈品牌:Oroton
2016/08/26 全球购物
捷克时尚网上商店:OTTO
2018/03/15 全球购物
Yves Rocher捷克官方网站:植物化妆品的创造者
2019/07/31 全球购物
2014小学年度工作总结
2014/12/20 职场文书
python3使用diagrams绘制架构图的步骤
2021/04/08 Python
Mysql数据库按时间点恢复实战记录
2021/06/30 MySQL
golang 语言中错误处理机制
2021/08/30 Golang