经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JS/JS库/框架 » Vue.js » 查看文章
vue实现websocket客服聊天功能
来源:jb51  时间:2021/10/8 17:43:05  对本文有异议

本文章主要介绍如何实现一个基本的聊天,后续会添加表情包,传照片等功能

其实刚开始接触的时候,我最大的疑惑是聊天功能的前期是否需要搭建什么框架、下载一些什么东西之类的,结果就是,其实websocket可以直接使用,然后前后端搭配,也是免费的,暂时没发现需要收费功能的东西。

实现效果图:

首先封装一个websocket.js文件(大家可以直接复制,然后把接收/发送数据之类的格式改成自己的就可以啦)

  1. import store from '@/store'
  2. var webSocket = null;
  3. var globalCallback = null;//定义外部接收数据的回调函数
  4.  
  5. //初始化websocket
  6. export function initWebSocket (url) {
  7. //判断浏览器是否支持websocket
  8. if ("WebSocket" in window) {
  9. webSocket = new WebSocket(url);//创建socket对象
  10. } else {
  11. alert("该浏览器不支持websocket!");
  12. }
  13. //打开
  14. webSocket.onopen = function () {
  15. webSocketOpen();
  16. };
  17. //收信
  18. webSocket.onmessage = function (msg) {
  19. webSocketOnMessage(msg);
  20. };
  21. //关闭
  22. webSocket.onclose = function () {
  23. webSocketClose();
  24. };
  25. //连接发生错误的回调方法
  26. webSocket.onerror = function () {
  27. console.log("WebSocket连接发生错误");
  28. };
  29. }
  30.  
  31. //连接socket建立时触发
  32. export function webSocketOpen () {
  33. console.log("WebSocket连接成功");
  34. }
  35.  
  36. //客户端接收服务端数据时触发,e为接受的数据对象
  37. export function webSocketOnMessage (e) {
  38. // 存储在store中,然后在聊天界面中监控变化 自动拿取收到的信息
  39. store.commit('user/SET_WS_MSG', e)
  40. }
  41.  
  42. //发送数据
  43. export function webSocketSend (data) {
  44. console.log('发送数据');
  45. //在这里根据自己的需要转换数据格式
  46. webSocket.send(JSON.stringify(data));
  47. }
  48.  
  49. //关闭socket
  50. export function webSocketClose () {
  51. webSocket.close()
  52. console.log("对话连接已关闭");
  53. // }
  54. }
  55.  
  56.  
  57. //在其他需要socket地方调用的函数,用来发送数据及接受数据
  58. export function sendSock (agentData, callback) {
  59. globalCallback = callback;//此callback为在其他地方调用时定义的接收socket数据的函数,此关重要。
  60. //下面的判断主要是考虑到socket连接可能中断或者其他的因素,可以重新发送此条消息。
  61. switch (webSocket.readyState) {
  62. //CONNECTING:值为0,表示正在连接。
  63. case webSocket.CONNECTING:
  64. setTimeout(function () {
  65. console.log('正在连接。。。');
  66. webSocketSend(agentData, callback);
  67. }, 1000);
  68. break;
  69. //OPEN:值为1,表示连接成功,可以通信了。
  70. case webSocket.OPEN:
  71. console.log('连接成功');
  72. webSocketSend(agentData);
  73. break;
  74. //CLOSING:值为2,表示连接正在关闭。
  75. case webSocket.CLOSING:
  76. setTimeout(function () {
  77. console.log('连接关闭中');
  78. webSocketSend(agentData, callback);
  79. }, 1000);
  80. break;
  81. //CLOSED:值为3,表示连接已经关闭,或者打开连接失败。
  82. case webSocket.CLOSED:
  83. console.log('连接关闭/打开失败');
  84. // do something
  85. break;
  86. default:
  87. // this never happens
  88. break;
  89. }
  90. }
  91.  
  92. //将初始化socket函数、发送(接收)数据的函数、关闭连接的函数export出去
  93. export default {
  94. initWebSocket,
  95. webSocketClose,
  96. sendSock
  97. };

在vuex中定义存储下接收的数据

store/modules/user.js

  1. let state = {
  2. webSocketMsg: ''
  3. };
  4.  
  5. //修改state
  6. const mutations = {
  7. // 存储websocket推送的消息
  8. SET_WS_MSG: (state, msg) => {
  9. state.webSocketMsg = msg
  10. }
  11. }
  12. //提交异动mutations。 如果在接受块出现问题,可以把这个加上去看看
  13. //const actions = {
  14. // webSockets ({ commit }) {
  15. // commit('SET_WS_MSG', 2)
  16. // }
  17. //}

store/getters.js

  1. //获取state的状态
  2. const getters = {
  3. webSocketMsg: state => state.user.webSocketMsg
  4. }
  5.  
  6. export default getters

然后在聊天界面中开始使用啦 websocket.vue

  1. <script>
  2. import { initWebSocket, sendSock, webSocketClose } from '@/utils/websocket.js'
  3. export default {
  4. data() {
  5. return {
  6. // 这个地址是后端给的,用来连接websocket。 加密wss 未加密ws
  7. wsUrl:'ws://地址',
  8. }
  9. },
  10. // 从store中获取接收到的信息
  11. computed: {
  12. getSocketMsg() {
  13. return this.$store.state.user.webSocketMsg
  14. },
  15. },
  16. //监控 getSocketMsg 是否有接收到数据
  17. watch: {
  18. getSocketMsg: {
  19. handler: function (val) {
  20. this.getConfigResult(val)
  21. },
  22. },
  23. //这一步是我对我聊天框的css设计,大家可以不用写,需要的时候再参考。
  24. //我将接收到的信息和发出的信息都存储到obList中,然后通过监控数值变化,使聊天定位始终位于底部(css中 overflow: auto;)
  25. obList: {
  26. handler: function (val) {
  27. this.$nextTick(() => {
  28. this.$refs.chatContent.scrollTop = this.$refs.chatContent.scrollHeight
  29. })
  30. },
  31. },
  32. immediate: true,
  33. },
  34. methods: {
  35. // 点击按钮-建立聊天连接
  36. customerDialog() {
  37. initWebSocket(this.wsUrl)
  38. },
  39. // 接收socket回调函数返回数据的方法,这个函数是我在监控接受数据的时候调用的(上面的watch中)
  40. getConfigResult(val) { },
  41.  
  42. // 点击发送按钮 发送信息---发送信息的格式要和后端确认
  43. sending() {
  44. sendSock('发送的信息')
  45. },
  46. // 处理聊天框关闭事件
  47. handleClose() {
  48. //关闭连接
  49. webSocketClose()
  50. },
  51. },
  52. }
  53. </script>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持w3xue。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号