✏️
ougege
  • README
  • Docs
    • index
    • Articles
      • AI
        • 体验Chrome AI
        • 体验Cloudflare Workers AI
        • 体验deepseek
      • CSS
        • CSS优化-PurgeCSS
        • 实用效果
        • 开发常用样式
      • Deepin
        • deepin20安装mysql
        • deepin使用tensorflow入门机器学习
        • deepin安装cuda和cuDNN
        • deepin安装lamp
        • deepin安装nvidia驱动
        • deepin安装oh my Zsh
        • deepin安装p7zip
        • deepin换源
        • 安装deepin系统后要做的事
      • Docker
        • CI/CD搭建配置
        • deepin搭建docker环境
        • docker安装和使用gitlab
        • docker搭建nginx+php环境
      • Essay
        • IOS申请邓白氏编码
        • Markdown-Mermaid
        • Markdown Use
        • webview白屏的问题查找和修复
        • 前端开发对接问题和解决办法汇总
        • 国务院机构改革方案
        • 国家级智库
        • 实用网站推荐
        • 常用Markdown数学公式语法
        • 强烈推荐前端要安装的vscode扩展
        • 新建销售计划-页面卡死问题分析
        • 海淘入坑手册
        • 竞品研究
        • 足球知识速成
      • Git
        • GitBook安装和常用命令
        • GitKraken免费版本
        • Git安装和配置
        • Git异常处理
        • Git Worktree使用
        • 前端工程化相关的实用git命令
      • JS
        • ESM模块导出方式对比
        • Emoji多端统一处理
        • JS发布订阅模式
        • JS性能优化
        • JS标准内置对象
        • JS链式调用原理
        • Promise介绍和使用
        • Range的使用
        • Vue+Oauth登录实现
        • Vue实现富文本插入Emoji
        • chrome扩展入门
        • es5新特性
        • es6常用特性
        • es常用片段
        • uniapp使用eslint校验代码
        • 与移动端通信
        • 优秀js库moment
        • 使用vue-socketio
        • 实现一个中间件
        • 小程序webview调试
        • 常用snippets
        • 常用正则
        • 常用的设计模式
        • 微信jssdk封装使用
        • 浏览器宏任务和微任务
        • 浏览器的5种Observer
        • 深入理解赋值、浅拷贝、深拷贝
        • 解析vue指令clickoutside源码
        • 键盘事件与KeyBoardWrapper交互
        • 高德地图常用方法封装
        • 高阶函数片段
      • Network
        • 使用Lighthouse分析前端性能
        • 前后端启用https
        • 宝塔nginx安装ngx_brotli
        • 比较gz与br加载速度
        • 浏览器https提示不安全
        • 浏览器提示HSTS
        • 简单使用tcpdump
        • 静态资源gzip优化
      • Node
        • CommonJS模块导出方式对比
        • Taro command not found 多平台解决方案
        • koa使用和API实现
        • node安装报错Unexpected-token
        • 使用nvm和nrm
        • 使用uniapp给小程序添加云函数
        • 使用verdaccio搭建本地npm仓库
        • 使用vue-cli搭建vue项目
        • 安装Node.js和npm配置
        • 编译成cjs和mjs的思路解析
        • 让你的npmPackage同时支持cjs和mjs
        • 通过GithubAction将内容部署到vps
      • Python
        • Python源管理
        • Python版本管理
        • mitmproxy抓包
        • 微信公众平台开发爬坑经历
      • Shell
        • Ubuntu安装deepin桌面环境
        • Ubuntu安装flatpak软件
        • Ubuntu安装wireshark
        • Ubuntu常见问题汇总
        • dell G3装系统无法识别第二块硬盘
        • linux下virtualbox用gho还原系统
        • mysql常用命令
        • navicat连接一键集成环境的mysql
        • nginx常用命令
        • pm2常用命令
        • virtualbox虚拟机和宿主机互相复制粘贴
        • vps内资源通过mega快传到本地
        • vps报错temporary failure in name resolution
        • vscode修改文件监控数
        • windows+linux双系统引导修复
        • zsh常用插件和命令
        • 一键搭建ChatGPT web版
        • 使用V2ray,CloudFlare Warp解锁GPT
        • 使用vscode进行java开发
        • 利用zx和SSHKey发布代码到服务器
        • 反爬虫一些方案总结和尝试
        • 安装1Panel
        • 安装Bt面板
        • 安装Ubuntu22.04后要做的事
        • 无显示器linux设置默认分辨率
        • 特别实用的shell命令
        • 解决linux安装xmind缺少依赖报错
      • Standards
        • CSS格式化之stylelint
        • CSS规范
        • HTML规范
        • JS规范
        • commit规范
        • 使用husky+commitlint规范代码提交
        • 使用semantic-release自动管理版本号
        • 命名规范
        • 图片规范
        • 版本编号规范
      • Wall
        • 科学上网-Cloudflare-Pages
        • 科学上网-Cloudflare-Warp
        • 科学上网-Geph
        • 科学上网-RackNerd
        • 科学上网-Slicehosting
        • 科学上网-Surfshark
        • 科学上网-Tor
        • 科学上网-XX-NET
        • 科学上网-heroku
        • 科学上网-shadowsock
        • 科学上网-v2ray使用
        • 科学上网-v2ray搭建
        • 科学上网-浏览器代理
        • 科学上网-让终端走代理
      • Windows
        • SourceTree破解免登录(windows版)
        • git bash交互提示符不工作
        • nexus 7 2013 wifi 刷机
        • tree命令生成文件目录
        • 利用charles抓包app
        • 安装Openssl
        • 安装msi文件报错2503和2502
        • 神器vimium使用说明
        • 自用host
        • 解决win10扩展出来的屏幕模糊
        • 解决安装Adobe Air时发生错误
    • Snippets
      • zsh
        • docker
        • extract
        • git-commit
        • git
        • mysql-macports
        • npm
        • nvm
        • pip
        • pm2
        • systemd
        • ubuntu
        • vscode
Powered by GitBook
On this page
  • 介绍
  • 实现
  • 参考

Was this helpful?

  1. Docs
  2. Articles
  3. JS

微信jssdk封装使用

介绍

在做项目中,有一个需求要在网页中实现自定义分享到微信的内容.加上了解过 jssdk ,为方便使用,进一步封装了 jweixin

实现

这里就不说明公众号怎么配置,后端怎么与微信签名了,可参考下面的博文,本篇主要展示前端分享功能代码实现

::: tip 安装 jweixin-module

npm i jweixin-module --save

:::

::: tip 封装 以下我使用了封装好的 util 和 api ::: details 点我查看代码

var jweixin = require('jweixin-module')
export default {  
  //判断是否在微信中  
  isWechat: function () {  
    var ua = window.navigator.userAgent.toLowerCase()
    if (ua.match(/micromessenger/i) == 'micromessenger') {  
      return true
    } else {  
      return false
    }  
  },  
  //初始化sdk配置  
  initJssdk: function(util, api, data, callback) {  
    //服务端进行签名:https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/JS-SDK.html#4
    let apiSrc = api.getWechatJsSign
    let params = {
      url: data.link
    }
    let tempToken = {'token': data.token}
    uni.showLoading()
    util.postData.call(this, apiSrc, params, 'POST', function (res) {
      if (res) {
        let data = res.data.data
        console.log(data)
        jweixin.config({
          debug: false, // 开启调试模式
          appId: data.appId, // 必填,公众号的唯一标识
          timestamp: data.timestamp, // 必填,生成签名的时间戳
          nonceStr: data.nonceStr, // 必填,生成签名的随机串
          signature: data.signature,// 必填,签名
          jsApiList: [
            'updateAppMessageShareData',//自定义“分享给朋友”及“分享到QQ”按钮的分享内容
            'updateTimelineShareData',//自定义“分享到朋友圈”及“分享到QQ空间”按钮的分享内容
            'onMenuShareWeibo',//获取“分享到腾讯微博”按钮点击状态及自定义分享内容接口
            'checkJsApi',  
            // 'onMenuShareTimeline',  
            // 'onMenuShareAppMessage'
          ], // 必填,需要使用的JS接口列表
          success: () => {
            console.log('success')
          },
          fail: () => {
            console.log('fail')
          }
        })
        //配置完成后,再执行分享等功能  
        if (callback) {
          callback(res.data.data)
        }
      }
      uni.hideLoading()
    }, function (res) {
      uni.hideLoading()
      uni.showToast({ title: res.errMsg, icon: 'none', duration: 1500 })
    }, tempToken)
  },
  //在需要自定义分享的页面中调用  
  share: function (util, api, data, type) {
    let url = data.url ? data.url : window.location.href
    //每次都需要重新初始化配置,才可以进行分享
    let signData
    this.initJssdk(util, api, data, function(signData) {
      signData = signData
    })
    jweixin.ready(function(){
      var shareData = {  
        title: data && data.title ? data.title : signData.site_name,
        desc: data && data.desc ? data.desc : signData.site_description,  
        link: url,
        imgUrl: data && data.img ? data.img : signData.site_logo,  
        success: function (res) {  
          //用户点击分享后的回调,这里可以进行统计,例如分享送金币之类的  
          // 关闭页面的弹框
          console.log('关闭页面的弹框')
        },
        cancel: function (res) {
          let errMsg = '分享失败,请咨询管理员'
          uni.showToast({ title: errMsg, icon: 'none', duration: 1500 })
        }
      }
      switch (type) {
        //分享给朋友接口
        case 1:
          jweixin.updateAppMessageShareData(shareData)
          // jweixin.onMenuShareAppMessage(shareData)
          break
        //分享到朋友圈接口
        case 2:
          jweixin.updateTimelineShareData(shareData)
          break
        default:
          jweixin.updateAppMessageShareData(shareData)
          // jweixin.onMenuShareAppMessage(shareData)
      }
    })
  }  
}

:::

::: tip 页面调用

// 引入
import {util, api, config, wechat} from '../../utils/index'

// 构建data对象,调用wechat方法
let data = {
  title: title,
  desc: desc,
  link: url,
  img: img,
  token: that.token
}
wechat.share(util, api, data, 1)

:::

参考

Previous常用的设计模式Next浏览器宏任务和微任务

Last updated 10 months ago

Was this helpful?

微信JSSdk实现分享功能
vue使用微信JS-SDK实现分享功能
uniapp中使用微信jssdk