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混合模式mix-blend-mode/background-blend-mode简介
Mar 15 HTML / CSS
使用 css3 transform 属性来变换背景图的方法
May 07 HTML / CSS
Css3+Js制作漂亮时钟(附源码)
Apr 24 HTML / CSS
html5中去掉input type date默认样式的方法
Sep 06 HTML / CSS
HTML5 语义化结构化规范化
Oct 17 HTML / CSS
html5桌面通知(Web Notifications)实例解析
Jul 07 HTML / CSS
HTML5有哪些新特征
Dec 01 HTML / CSS
使用phonegap进行本地存储的实现方法
Mar 31 HTML / CSS
HTML5 Blob 实现文件下载功能的示例代码
Nov 29 HTML / CSS
CSS filter 有什么神奇用途
May 25 HTML / CSS
html+css实现赛博朋克风格按钮
May 26 HTML / CSS
html5表单的required属性使用
Jul 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
php录入页面中动态从数据库中提取数据的实现
2006/10/09 PHP
php数组函数序列之array_unique() - 去除数组中重复的元素值
2011/10/29 PHP
有关PHP性能优化的介绍
2013/06/20 PHP
ThinkPHP查询中的魔术方法简述
2014/06/25 PHP
PHP图像处理类库及演示分享
2015/05/17 PHP
Laravel构建即时应用的一种实现方法详解
2017/08/31 PHP
pjblog修改技巧汇总
2007/03/12 Javascript
Js从头学起(基本数据类型和引用类型的参数传递详细分析)
2012/02/16 Javascript
node.js中的fs.utimes方法使用说明
2014/12/15 Javascript
封装好的js判断操作系统与浏览器代码分享
2015/01/09 Javascript
Js控制滑轮左右滑动实例
2015/02/13 Javascript
javascript属性访问表达式用法分析
2015/04/25 Javascript
bootstrap监听滚动实现头部跟随滚动
2016/11/08 Javascript
Zepto实现密码的隐藏/显示
2017/04/07 Javascript
js中let和var定义变量的区别
2018/02/08 Javascript
Node.js连接Sql Server 2008及数据层封装详解
2018/08/27 Javascript
轻量级富文本编辑器wangEditor结合vue使用方法示例
2018/10/10 Javascript
vue项目中使用bpmn为节点添加颜色的方法
2020/04/30 Javascript
Python获取央视节目单的实现代码
2015/07/25 Python
Python内置函数—vars的具体使用方法
2017/12/04 Python
scrapy爬虫实例分享
2017/12/28 Python
Python实现购物车购物小程序
2018/04/18 Python
Python脚本按照当前日期创建多级目录
2019/03/01 Python
python SVD压缩图像的实现代码
2019/11/05 Python
python 常用日期处理-- datetime 模块的使用
2020/09/02 Python
基于Python正确读取资源文件
2020/09/14 Python
巴西最大的体育用品商城:Netshoes巴西
2016/11/29 全球购物
《雷鸣电闪波尔卡》教学反思
2014/02/23 职场文书
本科毕业生求职自荐信
2014/04/09 职场文书
机关领导查摆四风思想汇报
2014/09/13 职场文书
政府班子四风问题整改措施
2014/10/04 职场文书
2014财务部年度工作总结
2014/12/08 职场文书
2016年4月份红领巾广播稿
2015/12/21 职场文书
2016教师校本研修心得体会
2016/01/08 职场文书
python读取pdf格式文档的实现代码
2021/04/01 Python
CentOS下安装Jenkins的完整步骤
2022/04/07 Servers