中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在Vue中通過配置WebSocket實現群聊功能

發布時間:2021-05-25 17:02:36 來源:億速云 閱讀:260 作者:Leah 欄目:web開發

怎么在Vue中通過配置WebSocket實現群聊功能?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

安裝依賴

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

怎么在Vue中通過配置WebSocket實現群聊功能

安裝成功

配置插件

在 main.js 中進行導入

import VueNativeSock from 'vue-native-websocket'

使用 VueNativeSock 插件,并進行相關配置

// 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;
 }
});

vuex的相關配置:mutations和actions添加相關函數

// 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: {
 }
})

至此 vue-native-websocket 配置結束,如需了解更多配置方法,請移步 npm倉庫

使用插件并實現群聊

在消息發送接收組件中添加 onmessage 監聽(mounted生命周期中)

// 監聽消息接收
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);
 }
 }
};

實現消息發送

// 消息發送函數
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 = "";
 }
}

實現頁面渲染

// 渲染頁面函數
renderPage: function(msgArray,msgObj,status){
 if(status===1){
 // 頁面第一次加載,如果本地存儲中有數據則渲染至頁面
 let msgArray = [];
 if(localStorage.getItem("msgArray")!==null){
 msgArray = JSON.parse(localStorage.getItem("msgArray"));
 for (let i = 0; i<msgArray.length;i++){
 const thisSenderMessageObj = {
 "msgText": msgArray[i].msg,
 "msgId": i,
 "avatarSrc": msgArray[i].avatarSrc,
 "userID": msgArray[i].userID
 };
 // 解析并渲染
 this.messageParsing(thisSenderMessageObj);
 }
 }
 }else{
 // 判斷本地存儲中是否有數據
 if(localStorage.getItem("msgArray")===null){
 // 新增記錄
 msgArray.push(msgObj);
 localStorage.setItem("msgArray",JSON.stringify(msgArray));
 for (let i = 0; i <msgArray.length; i++){
 const thisSenderMessageObj = {
 "msgText": msgArray[i].msg,
 "msgId": i,
 "avatarSrc": msgArray[i].avatarSrc,
 "userID": msgArray[i].userID,
 };
 // 解析并渲染
 this.messageParsing(thisSenderMessageObj);
 }
 }else{
 // 更新記錄
 msgArray = JSON.parse(localStorage.getItem("msgArray"));
 msgArray.push(msgObj);
 localStorage.setItem("msgArray",JSON.stringify(msgArray));
 const thisSenderMessageObj = {
 "msgText": msgObj.msg,
 "msgId": Date.now(),
 "avatarSrc": msgObj.avatarSrc,
 "userID": msgObj.userID
 };
 // 解析并渲染
 this.messageParsing(thisSenderMessageObj);
 }
 }
}

實現消息解析

// 消息解析
messageParsing: function(msgObj){
 // 解析接口返回的數據進行渲染
 let separateReg = /(\/[^/]+\/)/g;
 let msgText = msgObj.msgText;
 let finalMsgText = "";
 // 將符合條件的字符串放到數組里
 const resultArray = msgText.match(separateReg);
 if(resultArray!==null){
 for (let item of resultArray){
 // 刪除字符串中的/符號
 item = item.replace(/\//g,"");
 for (let emojiItem of this.emojiList){
 // 判斷捕獲到的字符串與配置文件中的字符串是否相同
 if(emojiItem.info === item){
 const imgSrc = require(`../assets/img/emoji/${emojiItem.hover}`);
 const imgTag = `<img src="${imgSrc}" width="28" height="28" alt="${item}">`;
 // 替換匹配的字符串為img標簽:全局替換
 msgText = msgText.replace(new RegExp(`/${item}/`,'g'),imgTag);
 }
 }
 }
 finalMsgText = msgText;
 }else{
 finalMsgText = msgText;
 }
 msgObj.msgText = finalMsgText;
 // 渲染頁面
 this.senderMessageList.push(msgObj);
 // 修改滾動條位置
 this.$nextTick(function () {
 this.$refs.messagesContainer.scrollTop = this.$refs.messagesContainer.scrollHeight;
 });
}

DOM結構

通過每條消息的userID和vuex中的存儲的當前用戶的userID來判斷當前消息是否為對方發送

<!--消息顯示-->
<div class="messages-panel" ref="messagesContainer">
 <div class="row-panel" v-for="item in senderMessageList" :key="item.msgId">
 <!--發送者消息樣式-->
 <div class="sender-panel" v-if="item.userID===userID">
 <!--消息-->
 <div class="msg-body">
 <!--消息尾巴-->
 <div class="tail-panel">
 <svg class="icon" aria-hidden="true">
 <use xlink:href="#icon-zbds30duihuakuangyou" rel="external nofollow" ></use>
 </svg>
 </div>
 <!--消息內容-->
 <p v-html="item.msgText"/>
 </div>
 <!--頭像-->
 <div class="avatar-panel">
 <img :src="item.avatarSrc" alt="">
 </div>
 </div>
 <!--對方消息樣式-->
 <div class="otherSide-panel" v-else>
 <!--頭像-->
 <div class="avatar-panel">
 <img :src="item.avatarSrc" alt="">
 </div>
 <!--消息-->
 <div class="msg-body">
 <!--消息尾巴-->
 <div class="tail-panel">
 <svg class="icon" aria-hidden="true">
 <use xlink:href="#icon-zbds30duihuakuangzuo" rel="external nofollow" ></use>
 </svg>
 </div>
 <!--消息內容-->
 <p v-html="item.msgText"/>
 </div>
 </div>
 </div>
</div>

vue是什么

Vue是一套用于構建用戶界面的漸進式JavaScript框架,Vue與其它大型框架的區別是,使用Vue可以自底向上逐層應用,其核心庫只關注視圖層,方便與第三方庫和項目整合,且使用Vue可以采用單文件組件和Vue生態系統支持的庫開發復雜的單頁應用。

關于怎么在Vue中通過配置WebSocket實現群聊功能問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

喜德县| 达孜县| 石河子市| 黄梅县| 丰县| 桑日县| 济源市| 西藏| 松滋市| 宿迁市| 潼南县| 绩溪县| 聂荣县| 民勤县| 淮北市| 焦作市| 贡觉县| 荣昌县| 隆回县| 六枝特区| 扎赉特旗| 溧水县| 齐齐哈尔市| 德昌县| 中方县| 呼玛县| 太原市| 高碑店市| 元江| 晋江市| 新泰市| 交城县| 甘孜县| 南城县| 曲沃县| 永仁县| 佳木斯市| 台北县| 芜湖市| 罗江县| 阜平县|