微信号:JavaScriptcn

介绍:面向JavaScript爱好人员提供:前端最新资讯、原创内容、JavaScript、HTML5、Ajax、jQuery、Node.js等一系列教程和经验分享.

H5页面在微信端的分享

2018-09-03 08:40 JavaScript

微信分享,咋一看好像很复杂,实则非常简单。只需要调用微信官方出的微信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文件

 
           
  1. <script src="https://res.wx.qq.com/open/js/jweixin-1.2.0.js" type="text/javascript"></script>

2、基本配置

 
           
  1. wx.config({

  2.  debug: false, // 是否开启调试模式

  3.  appId: appid, //appid

  4.  timestamp: timestamp, // 时间戳

  5.  nonceStr: noncestr, // 随机字符串

  6.  signature: signature, // 签名

  7.  jsApiList: [

  8.    'onMenuShareTimeline',

  9.    'onMenuShareAppMessage',

  10.    'onMenuShareQQ',

  11.    'onMenuShareWeibo',

  12.    'onMenuShareQZone'

  13.  ] // 需要使用的JS接口列表

  14. })

3、使用

 
           
  1. wx.ready(function(){

  2.  // 分享给好友

  3.  wx.onMenuShareAppMessage({

  4.    title: title, // 分享标题

  5.    desc: desc, // 分享描述

  6.    link: link, // 分享链接

  7.    imgUrl: imgUrl, // 分享图标

  8.    success: function () {

  9.      doShareDone()

  10.    },

  11.    cancel: function () {

  12.      doShareCancel()

  13.    }

  14.  })

  15. // 分享到朋友圈

  16.  wx.onMenuShareTimeline({

  17.    title: title, // 分享标题

  18.    link: link, // 分享链接

  19.    imgUrl: imgUrl, // 分享图标

  20.    success: function () {

  21.      doShareDone()

  22.    },

  23.    cancel: function () {

  24.      doShareCancel()

  25.    }

  26.  })

  27. })

  28. // 分享成功回调

  29. function doShareDone () {

  30.  console.log('分享成功')

  31. }

  32. // 取消分享回调

  33. function doShareCancel () {

  34.  console.log('取消了分享')

  35. }

三、调试

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无效。


作者:stardew

https://segmentfault.com/a/1190000016199418


 
JavaScript 更多文章 Async:简洁优雅的异步之道 如果你喜欢《权利的游戏》就一定要看《代码的游戏》 Babel 7.0 正式发布,JavaScript 编译器 vue.js响应式原理解析与实现 小程序开发没有技术含量?
猜您喜欢 平安云测试平台 《半场无战事》观影 进程概述和内存分配 这款小程序,让你上班不迟到,下班早回家 中国技术力量:中国技术开放日亮相QCon旧金山