所有分类
  • 所有分类
  • 后端开发
Vue项目神器!快学会使用vue-native-websocket实现群聊功能

Vue项目神器!快学会使用vue-native-websocket实现群聊功能

库的使用以及配置,用其实现群聊功能。插件,并进行相关配置使用插件并实现群聊通过每条消息的userID和vuex中的存储的当前用户的userID来判断当前消息是否为对方发送以上所述是小编给大家介绍的Vue通过配置WebSocket并实现群聊功

咱们要讲个jquery项目,用了websocket省事多了,不必费劲儿解决那些乱七八糟的模块和组件问题,按照文档来就行!不过到了Vue项目这可不大一样喔!得考虑各种可能出现的情况哩。那给你介绍下“vue-native-websocket”这个神奇的东东,帮你在Vue项目里顺顺利利搞起群聊来!别着急,先看看我们做出来的效果图呗~

vue-native-websocket安装
# yarn | npm 安装
yarn add vue-native-websocket | npm install vue-native-websocket --save

咱们今儿就来聊聊怎么在Vue项目中用websocket。你可能觉得这个复杂一点,但实际上要针对每个问题进行详细分析!我今天就想跟大家说说怎么使用vue-native-websocket,还有它的用法和配置之类的东西。不过要先说好要是没学会vuex那可能就要费劲了。

得了,咱们赶紧上手呗,使用这VENUE-NATIVE-WEBSOCKET插件先。首先,你得把它加到MAIN.JS文件里去。别忘了给它设置点参数另外,就是在VUEX的mutations和actions那块儿安插个相应的函数就完事儿了。

// main.js
// base.lkWebSocket为你服务端websocket地址
Vue.use(VueNativeSock,base.lkWebSocket,{
 // 启用Vuex集成,store的值为你的vuex
 store: store,
 // 数据发送/接收使用使用json格式
 format: "json",
 // 开启自动重连
 reconnection: true,
 // 尝试重连的次数
 reconnectionAttempts: 5,
 // 重连间隔时间
 reconnectionDelay: 3000,
 // 将数据进行序列化,由于启用了json格式的数据传输这里需要进行重写
 passToStoreHandler: function (eventName, event) {
 if (!eventName.startsWith('SOCKET_')) { return }
 let method = 'commit';
 let target = eventName.toUpperCase();
 let msg = event;
 if (this.format === 'json' && event.data) {
 msg = JSON.parse(event.data);
 if (msg.mutation) {
 target = [msg.namespace || '', msg.mutation].filter((e) => !!e).join('/');
 } else if (msg.action) {
 method = 'dispatch';
 target = [msg.namespace || '', msg.action].filter((e) => !!e).join('/');
 }
 }
 this.store[method](target, msg);
 this.store.state.socket.message = msg;
 }
});

快来学着怎么用群聊!只需在信息接收那边添上一个onmessage监测器(和安装时的位置一样哈),这样就能畅快地聊天了!

Vue项目神器!快学会使用vue-native-websocket实现群聊功能

// vuex配置文件
import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex);
export default new Vuex.Store({
 state: {
 token:"",
 userID:"",
 // 用户头像
 profilePicture: "",
 socket: {
 // 连接状态
 isConnected: false,
 // 消息内容
 message: '',
 // 重新连接错误
 reconnectError: false
 }
 },
 mutations: {
 SOCKET_ONOPEN (state, event) {
 // 连接打开触发的函数
 Vue.prototype.$socket = event.currentTarget;
 state.socket.isConnected = true
 },
 SOCKET_ONCLOSE (state, event) {
 // 连接关闭触发的函数
 state.socket.isConnected = false;
 console.log(event);
 },
 SOCKET_ONERROR (state, event) {
 // 连接发生错误触发的函数
 console.error(state, event)
 },
 SOCKET_ONMESSAGE (state, message) {
 // 收到消息时触发的函数
 state.socket.message = message
 },
 SOCKET_RECONNECT(state, count) {
 // 重新连接触发的函数
 console.info(state, count)
 },
 SOCKET_RECONNECT_ERROR(state) {
 // 重新连接失败触发的函数
 state.socket.reconnectError = true;
 },
 },
 actions: {
 customerAdded (context) {
 // 新连接添加函数
 console.log('action received: customerAdded');
 console.log(context)
 }
 },
 modules: {
 }
})

别忘了搞定发消息、网页渲染还有分析消息这三个大件事。这就像做饭,每一步都不能少!加油,核对好每一条消息中 userID 是否与咱们vuex里存着的那个人一致。

Vue搭建个聊天室,咋整?赶紧给你们说说,希望帮到你!

// 监听消息接收
this.$options.sockets.onmessage = (res)=>{
 // res.data为服务端返回的数据
 const data = JSON.parse(res.data);
 // 200为服务端连接建立成功时返回的状态码(此处根据真实后端返回值进行相应的修改)
 if(data.code===200){
 // 连接建立成功
 console.log(data.msg);
 }else{
 // 获取服务端推送的消息
 const msgObj = {
 msg: data.msg,
 avatarSrc: data.avatarSrc,
 userID: data.userID
 };
 // 渲染页面:如果msgArray存在则转json
 if(lodash.isEmpty(localStorage.getItem("msgArray"))){
 this.renderPage([],msgObj,0);
 }else{
 this.renderPage(JSON.parse(localStorage.getItem("msgArray")),msgObj,0);
 }
 }
};

好,今天咱们就先聊到这儿!想了解更多设置信息的朋友,赶紧翻翻npm仓库,肯定有收获!别忘了用vue-native-websocket这款插件搞起群聊玩耍加油鸭!所有的都告诉你们!希望你们会喜欢这篇推送哦(比心)。如果有啥问题或建议尽管找我记得也要和小伙伴们分享哟~

// 消息发送函数
sendMessage: function (event) {
 if (event.keyCode === 13) {
 // 阻止编辑框默认生成div事件
 event.preventDefault();
 let msgText = "";
 // 获取输入框下的所有子元素
 let allNodes = event.target.childNodes;
 for(let item of allNodes){
 // 判断当前元素是否为img元素
 if(item.nodeName==="IMG"){
 msgText += `/${item.alt}/`;
 }
 else{
 // 获取text节点的值
 if(item.nodeValue!==null){
  msgText += item.nodeValue;
 }
 }
 }
 // 消息发送: 消息内容、状态码、当前登录用户的头像地址、用户id
 this.$socket.sendObj({msg: msgText,code: 0,avatarSrc: this.$store.state.profilePicture,userID: this.$store.state.userID});
 // 清空输入框中的内容
 event.target.innerHTML = "";
 }
}

原文链接:https://www.icz.com/technicalinformation/web/javascript/2024/03/11507.html,转载请注明出处~~~
0

评论0

请先
注意:请收藏好网址www.icz.com,防止失联!站内免费资源持续上传中…!赞助我们
显示验证码
没有账号?注册  忘记密码?