• H5 页面在微信端的分享


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

     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  // 分享到朋友圈
    17   wx.onMenuShareTimeline({
    18     title: title, // 分享标题
    19     link: link, // 分享链接
    20     imgUrl: imgUrl, // 分享图标
    21     success: function () {
    22       doShareDone()
    23     },
    24     cancel: function () {
    25       doShareCancel()
    26     }
    27   })
    28 })

    三、调试

    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成功的配置,就可以再继续配置其它分享,哪怕这个分享配置的signature无效。

  • 相关阅读:
    无废话MVC入门教程五[Control与View交互]
    无废话MVC入门教程三[路由设置及视图入门]
    无废话MVC入门教程二[第一个小Demo]
    IDEA 插件开发
    慢慢学Linux驱动开发,第十章,GNU C的扩展
    《UNIX环境高级编程》编译问题彻底解决方案
    GNU make笔记
    outlook2003无法显示地址列表 无法打开与该地址列表的相关"联系人"文件夹解决方案
    慢慢学Linux驱动开发,第十二章,加入内核
    ADS: (Fatal)L6002U:Could not open file:..... & L6002
  • 原文地址:https://www.cnblogs.com/ljx20180807/p/9729468.html
Copyright © 2020-2023  润新知