VueH5公众号分享到微信朋友圈或好友

场景需求:

一般分享场景是在当前页面分享当前页面,但是业务需求是,在当前页面分享好几个其他页面的链接到朋友圈和好友。

PS:微信自带的分享面板是无法第三方唤起的,只能点三个点。

其次在微信公众号页也不支持自定义的按钮来唤起分享好友的列表。 因此只能提示用户自己去点右上方三个点来唤起!!!

解决方法: 

在点击分享后,弹出指示图片遮罩,暗地跳转到新的页面。

前期准备:

1.绑定域名

先登录微信公众平台进入"公众号设置"—>"功能设置"里填写如下的JS接口安全域名 备注:登录后可在“开发者中心”查看对应的接口权限。

ps:可能还有公众号权限、ip白名单的配置。

2.安装weixin-js-sdk
npm i weixin-js-sdk 
3.调用微信配置的文件,直接复制即可。
在utils下面新建wxShare.js
/* eslint-disable*/
import wx from "weixin-js-sdk"; //微信sdk依赖
const jsApiList = ["onMenuShareAppMessage", "onMenuShareTimeline"];
//要用到微信API
function getJSSDK(data, dataForWeixin) {wx.config({debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。appId: "wx8f663359de28f56c", // 必填,公众号的唯一标识timestamp: data.timestamp, // 必填,生成签名的时间戳nonceStr: data.nonceStr, // 必填,生成签名的随机串signature: data.signature, // 必填,签名jsApiList: jsApiList, // 必填,需要使用的JS接口列表success: () => {alert("success");},});wx.ready(function () {wx.onMenuShareAppMessage({title: dataForWeixin.title,desc: dataForWeixin.desc,link: dataForWeixin.link,imgUrl: dataForWeixin.imgUrl,trigger: function trigger(res) {// alert(111);},success: function success(res) {// alert('已分享');},cancel: function cancel(res) {// alert('已取消');},fail: function fail(res) {// alert('进来了');},});// 2.2 监听“分享到朋友圈”按钮点击、自定义分享内容及分享结果接口wx.onMenuShareTimeline({title: dataForWeixin.title,link: dataForWeixin.link,imgUrl: dataForWeixin.imgUrl,trigger: function trigger(res) {// alert(11);// alert('用户点击分享到朋友圈');},success: function success(res) {// alert('已分享');},cancel: function cancel(res) {//alert('已取消');},fail: function fail(res) {// alert(JSON.stringify(res));},});});wx.error((res) => {alert(stringify(res));console.log(JSON.stringify(res) + "微信验证失败");});
}
export default {// 获取JSSDKgetJSSDK: getJSSDK,
};
4. 后端接口返回wx.config所需的配置信息。
5.页面调用。

关键点:

1.调用接口时的url是当前页面的url。

2.在跳转到所要分享的页面时候,不能用router.push,为了兼容ios,需要使用window.location.replace。

3.分享的图标,放置在assets下面。但是配置需要放置网络地址。当项目打包完成后所有的图片都会在dist的img文件夹里面,所以可以直接在配置时写{{域名.com/img/图片名}}。

4.如果有二维码图片的话想长按识别二维码,不能放置为背景图片,只能放做img。

5.微信公众号的H5会自带缓存,所以需要去掉缓存。在dist文件加时间戳。

在Vue.config.js里面
const version = new Date().getTime();
const mode = process.env.NODE_ENV;
const isDev = mode === "development";
在mudule.export上面// CSS 相关选项css: {extract: {// 打包后css文件名称添加时间戳filename: isDev ? "[name].css" : `css/[name].${version}.css`,chunkFilename: isDev ? "[name].css" : `css/chunk.[id].${version}.css`,},loaderOptions: {css: {},postcss: {plugins: [require("postcss-px2rem")({remUnit: 37.5,}),],},},},configureWebpack: {output: {filename: isDev ? "[name].js" : `js/[name].[chunkhash:10].${version}.js`,chunkFilename: isDev? "[name].js": `js/[id].[chunkhash:10].${version}.js`,},},
import { shareWx } from "@/api/port";mounted() {this.toWxAgentShare();},methods: {//招募代理的分享到朋友圈toWxAgentShare() {let url = window.location.href.split("#")[0];shareWx({ url }).then((res) => {if (res.data.code == 200) {const { data } = res.data;let bankShare = {title: "自定义标题",desc: "自定义描述",link: `需要分享的链接?phone=${this.phone}&code=${this.code}`,imgUrl: "域名/img/Share.png", 分享的图片};wxShare.getJSSDK(data, bankShare);}});},toWxAgentShare() {window.location.replace(`${process.env.VUE_APP_H_URL}insure/bankShare`);},
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/154480.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

redis---非关系型数据库

关系数据库与非关系型数据库 redis非关系型数据库,又名缓存型数据库。数据库类型:关系型数据库和非关系型数据库关系型数据库是一 个机构化的数据库,行和列。 列:声明对象。 行:记录对象属性。 表与表之间的的关联。 sql语句&…

Linux fork和vfork函数用法

fork和vfork是用于创建新进程的函数,在Linux的C语言编程中非常常见。 fork函数 fork函数是用于创建一个新的进程,新进程是调用进程的副本。新进程将包含调用进程的地址空间、文件描述符、栈和数据。在fork之后,父进程和子进程将并发执行。 …

【giszz笔记】产品设计标准流程【5】

(续上回) 目录 五、原型设计 1.写在前面的话 2.原型是什么 3.画原型的工具 4.产品经理的复合能力 5.关于原型图 PS:这个系列,主要讨论的是产品设计的一般标准流程。这个流程也许每天都发生在我们的身边,我们也常…

MatrixOne完成与麒麟信安、欧拉的兼容互认

近日,超融合异构云原生数据库MatrixOne企业版软件V1.0完成了与欧拉开源操作系统(openEuler简称“欧拉”)、麒麟信安操作系统系列产品和虚拟化平台的相互兼容认证,通过了欧拉兼容性测评,获得了《openEuler技术测评证书》…

Pycharm run 输出界面控制一行能够输出的元素个数

Pycharm run 输出界面控制一行能够输出的元素个数 今天遇到了一个问题,当我们在 Pycharm 中打印输出数组时,如果数组一行的元素个数过多,那么我们在打印时就会出现以下问题。 代码如下: import numpy as npx np.array([[0., 0.7…

webstorm配置console.log打印

一、设置面板 打开设置面板(windows 快捷键: ctrl alt s) ,找到 编辑器 -> 实时模板 -> JavaScript -> log,点击log会出现对应的配置 二、模板文本 将下面这些模板文本粘贴进去 console.info("🚀 ~ file:$file…

Gensim库——文本处理和主题建模的强大工具

在信息时代,海量的文本数据不断地涌现。如何从这如山如海的文本中提取有意义的信息,成为了一项关键任务。Python语言提供了许多优秀的库和工具来处理文本数据,其中一款备受推崇的工具就是Gensim库。Gensim是一个开源的Python库,它…

洗衣行业在线预约小程序源码系统 附带完整的搭建教程

目前,人们对生活品质的追求不断提高,但生活节奏却也不断加快。对品质的追求遇到了忙碌的生活节奏,人们更渴望以最简单、便捷的方式达到追求品质的目的。同时,由于线上支付的普及,大家更希望足不出户就可以解决自己生活…

“三面一体”的业务调度方案在运营商订单运营的实践

在当前信息化时代,运营商的业务流程复杂度和多样性持续增长,多个系统、部门以及相关事务需要进行高效准确的调度。如何在这样的背景下,保证业务流程的顺畅,业务信息的实时传递以及业务决策的准确性,是业务运营面临的重…

seleninum 基础及简单实践

网页自动化 1 Selenium自动化基础 1.1 Selenium简介 Selenium自动化流程如下: 自动化程序调用Selenium客户端库函数客户端库会发送Selenium命令,给浏览器的驱动程序浏览器驱动程序接收到命令后,驱动浏览器去执行命令浏览器执行命令浏览器驱…

Java基本数据类型与引用类型的区别

晒个小暖 南方人的冬天,太阳总是很赏脸,花花草草长得很漂亮,厚棉被晒得很舒服,腊肠腊肉腊鸭油光发亮,就这样站在日光下一会吧,你也会变得亮亮堂堂,和和融融。不管是不是冬天,没有什…

3.ubuntu20.04环境的ros搭建

ros搭建比较简单,主要步骤如下: 1.配置ros软件源: sudo sh -c echo "deb http://packages.ros.org/ros/ubuntu $(lsb_release -sc) main" > /etc/apt/sources.list.d/ros-latest.list 2.配置密钥 sudo apt-key adv --keyser…

小众市场:探索跨境电商中的利基领域

随着全球数字化和互联网的普及,跨境电子商务已经成为了一个蓬勃发展的产业。从亚马逊到阿里巴巴,大型电商平台已经占据了很大一部分市场份额。 然而,在这个竞争激烈的领域,寻找小众市场和利基领域可能是一种成功的策略。本文将探…

HR问:有没有免费的人才测评工具?

人才测评工具分为两种,一种是测评量表,一种是操作量表的工具,在线测评的方式没有普及之前,很多朋友都习惯把测评量表(测评试题)称为测评工具,其实我认为量表就是量表,而试试量表测评…

【图数据库实战】图数据库基本概念

1、图数据库的概念 维基百科图书库的概念: 在计算机科学中,图数据库(英语:graph database,GDB)是一个使用图结构进行语义查询的数据库,它使用节点、边和属性来表示和存储数据。该系统的关键概念…

Spring Boot 与 Gzip 压缩

响应压缩是 Web 应用一种常见的优化手段,通过压缩算法减小传输数据的体积,提高传输效率、节约带宽。客户端接收到数据后,使用相同的算法对数据进行解压从而获取到原始数据。 客户端和服务器需要通过 Header 来协商双方支持的压缩算法。 Acc…

win10 火绒 每次打开word、excel都会提示,你要如何打开这个文件

一、概述 最近电脑每次打开办公软件,比如word、excel等,都会提示让选择如何打开这个文件?即使是默认程序已经关联的启动文件,也是会提示,不管是设置“始终使用此应用打开.xIsx 文件”几次,还是一样的提示&…

python接口自动化测试之接口数据依赖

一般在做自动化测试时,经常会对一整套业务流程进行一组接口上的测试,这时候接口之间经常会有数据依赖,那又该如何继续呢? 那么有如下思路: 抽取之前接口的返回值存储到全局变量字典中。初始化接口请求时,…

深度了解LinkedBlockingQueue底层实现原理

文章目录 前言一、Queue接口的定义二、AbstractQueue实现Queue的基本操作1.AbstractQueue源码注释解析2.方法add、remove、element、clear、addAll的实现原理 三、BlockingQueue接口定义解析1.入列操作2.出列操作3.其他操作 四、LinkedBlockingQueue源码解析1.LinkedBlockingQu…