当前位置: 首页 > news >正文

企业微信内嵌H5项目接入聊天功能

产品需求是,在列表中把符合条件的列表接入聊天功能,以下是详细步骤:

1.引入企业微信

<script src="https://res.wx.qq.com/wwopen/js/jsapi/jweixin-1.0.0.js"></script>

 2.获取wx签名(必须要)

/*** 获取wx签名**/
export function getWxJsApi(data) {return request({url: '/js-sdk',method: 'post',data})
}

3.封装组件(两个)

wxConfig.js

import {getWxJsApi} from "@/api/arrives";export const wxConfig = async (url, jsApiList, jsApiListChat) => {try {let res = await getWxJsApi({url});if (res && res.status === 200) {const { corpId, nonceStr, signature, timeStamp } = res.datawx &&wx.config({beta: true,// 必须这么写,否则wx.invoke调用形式的jsapi会有问题debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。appId: corpId, // 必填,企业微信的corpID,必须是本企业的corpID,不允许跨企业使用timestamp: timeStamp, // 必填,生成签名的时间戳nonceStr, // 必填,生成签名的随机串signature,// 必填,签名,见 附录-JS-SDK使用权限签名算法jsApiList,});wx &&wx.ready(() => {if (jsApiListChat) {getWxJsApi ({url}).then(result => {if (res.status === 200) {wx.agentConfig({beta: true,// 必须这么写,否则wx.invoke调用形式的jsapi会有问题debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。appId: result.data.corpId, // 必填,企业微信的corpID,必须是本企业的corpID,不允许跨企业使用timestamp: result.data.timeStamp, // 必填,生成签名的时间戳nonceStr: result.data.nonceStr, // 必填,生成签名的随机串signature: result.data.signature,// 必填,签名,见 附录-JS-SDK使用权限签名算法jsApiList:jsApiListChat});}})}wx.error(function() {console.log('error');});});}} catch(error) {} 
}

mixin.js

import {wxConfig} from '@/utils/wxConfig'
const chatMixin = {mounted() {let url = location.hrefwxConfig(url, ['openEnterpriseChat','checkJsApi'], ['selectExternalContact', 'getCurExternalContact'])},methods: {wxEnterpriseChat (obj) {wx &&wx.checkJsApi({jsApiList: ['openEnterpriseChat'],success: function (res) {wx.openEnterpriseChat({...obj,groupName: '',chatId: "",success: function(res) {var chatId = res.chatId;// 回调},fail: function(res) {if(res.errMsg.indexOf('function not exist') > -1){alert('版本过低请升级')}}})},fail: function(error) {console.log(error)}})}}
}export {chatMixin}

4.页面上使用

<1>引入

import {chatMixin} from "@/utils/mixin";
export default {mixins: [chatMixin],
}

html

<div class="right-customer-detail flex" v-if="enterpriseWeChatUserId == item.userAccountId && item.externalUserId"><imgsrc="https://static-resource.dossen.com/H5/marketing/img/wechat.png"class="wechat-img"@click.stop="() => testChat(item.externalUserId)"/></div>

methods:

 testChat(externalUserIds) {let obj = {externalUserIds}this.wxEnterpriseChat(obj)},

已结束

备注: 

这里的this.wxEnterpriseChat就是上面mixin.js封装的方法

http://www.lryc.cn/news/377498.html

相关文章:

  • 微信小程序 this.setData高级用法(只更改单个数据)
  • 使用npm发布自己的插件包
  • 前端入门篇(五十二)练习6:transition过渡小动画
  • scrapy模块的基础使用
  • 如何在不降低网络安全防护的前提下,优化pcdn的流量清洗效率?
  • linux发行版CentOS、Debian和Ubuntu的对比
  • WordPress如何删除内存中的缓存?
  • 【XML模版文件参数初始化】
  • Golang | Leetcode Golang题解之第160题相交链表
  • 基于FOC控制器的BLDC无刷直流电机控制系统matlab编程与仿真
  • ffmpeg转换视频格式
  • 设计程序,利用栈实现数值转换
  • QSharedMemory使用详解
  • 中电金信:保险业多项举措共绘数字化转型新篇章
  • Gartner发布2024年人工智能技术成熟度曲线:29项决定人工智能领域发展方向的前沿和趋势性技术
  • 顺势而为:雷军、小米与创业成功的深层思考
  • Java+ffmpeg 合并两个mp4文件
  • 汽车IVI中控开发入门及进阶(三十一):视频知识扫盲
  • 【后端】Java学习笔记(二周目-1)
  • PDF文档翻译软件哪个好?分享5款快速翻译的工具
  • 哪些因素驱动新零售发展?新零售与传统零售、电子商务区别在哪?
  • 使用代理IP常见问题及解答
  • 重磅!鹅厂大牛带你30分钟玩转AI智能结对编程!
  • 研究Redis源码的一些前期准备
  • 用PHP来调用API给自己定制一个“每日新闻”
  • AGI时代,程序员想学习大语言模型(LLM),应该从哪里开始?
  • Vue在表单校验中trigger属性指定何时触发校验规则
  • 【多线程实例】
  • 数据治理在数据提取中的角色:确保数据质量和安全
  • Nuxt快速学习开发 - Nuxt3静态资源Assets