亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue+express+Socket實現(xiàn)聊天功能

 更新時間:2021年06月28日 17:23:54   作者:零度°K  
這篇文章主要為大家詳細介紹了Vue+express+Socket實現(xiàn)聊天功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了Vue+express+Socket實現(xiàn)聊天功能的具體代碼,供大家參考,具體內(nèi)容如下

實現(xiàn)聊天功能

具體功能

只是為了實現(xiàn)功能,不對界面進行美化

1、輸入消息點擊發(fā)送所有用戶可以在下方收到消息

2、輸入userid后點擊連接,可以連接對應(yīng)的聊天,另外一個界面輸入剛剛那個頁面的userid后再輸入內(nèi)容點擊發(fā)送給指定的人,則剛才那個頁面可以打印輸出,而其他頁面不會收到,實現(xiàn)私聊的功能

3、沒有具體實現(xiàn)私聊的內(nèi)容顯示,但是接收發(fā)送消息都可以實現(xiàn),要實現(xiàn)私聊的內(nèi)容顯示可以再添加一個私聊頁面

界面截圖

項目準備

只對socket準備進行介紹,Vue和express的搭建不進行介紹

前端 socket

安裝

npm i vue-socket.io --save

導(dǎo)入

import VueSocketIO from 'vue-socket.io'

后臺socket

安裝

npm i socket.io --save

導(dǎo)入

在express-generator生產(chǎn)的bin/www文件夾中加入

var io = require('socket.io')(server)'
io.on('connection',  (socket) => {
  socket.on('demining',  (data) => {
    console.log(data);
  });
});

具體截圖如下:

項目實現(xiàn)

Vue代碼

HTMl代碼

<div class="home">
    userid: <input type="text" v-model="userid">
    昵稱:<input type="text" v-model="name">
    消息:<input type="text" v-model="msg" />
    <button @click="send">發(fā)送</button>
    <button @click="join">連接</button>
    <button @click="sendmsg">發(fā)送給指定的人</button>

    <ul>
      <li v-for="(item,index) in chatList" :key="item.name + index">
        {{ item.name }}說:{{ item.msg }}
      </li>
    </ul>
</div>

js代碼

export default {
  name: "Home",
  data() {
    return {
      users: [],
      msg: "",
      chatList: [],
      name: '',
      userid: ''
    };
  },
  sockets: {
    // 連接后臺socket
    connect() {
      console.log('socket connected');
    },
    // 用戶后臺調(diào)用,添加數(shù)據(jù)
    sendMessage(data) {
      console.log(data);
      this.chatList.push(data)
    },
    // 用戶后臺調(diào)用,打印數(shù)據(jù)
    receivemsg(data) {
      console.log('receivemsg');
      console.log(data);
    }
  },
  methods: {
    // 發(fā)送消息給后臺
    send() {
      // 使用emit調(diào)用后臺的socket中的message方法
      this.$socket.emit("message", {
        userid: 100,
        name: this.name,
        msg: this.msg
      });
    },
    // 建立用戶連接
    join() {
      this.$socket.emit("join", {
        userid: this.userid
      });
    },
    // 發(fā)送消息給后臺 用于私發(fā)消息
    sendmsg() {
      this.$socket.emit("sendmsg", {
        userid: this.userid,
        msg: this.msg
      });
    }
  }
};

express代碼

在剛才的www文件定義的連接中添加一下代碼

// 用于存儲每個用戶的socket,實現(xiàn)私聊的功能
let arrAllSocket = {}
// 穿件socket連接
io.on('connection', (socket) => {
  console.log('連接上了');
  // console.log(socket);
  // join函數(shù) 用于用戶連接
  socket.on('join', function (obj) {
    console.log(obj.userid + 'join')
    // 保存每個用戶的連接狀態(tài) 用于私發(fā)消息
    arrAllSocket[obj.userid] = socket
  })
  // 接收前臺發(fā)送的消息 函數(shù)名為message
  socket.on('message', (data) => {
    console.log(data);
    // 將消息發(fā)送回前臺(調(diào)用前臺定義的方法) 函數(shù)名為sendMessage
    io.emit('sendMessage', data);
  });
  // 私發(fā)消息
  socket.on('sendmsg', function (data) {
    console.log(data);
    // 查詢用戶連接
    let target = arrAllSocket[data.userid]
    if (target) {
      //發(fā)送信息至指定的人
      target.emit('receivemsg', data)
    }
  })
})

后臺代碼封裝

由于www文件不應(yīng)該寫太多代碼,所以對這一部分代碼進行封裝

1、在項目目錄下創(chuàng)建一個io的文件夾,結(jié)構(gòu)如下

2、將剛才的那部分代碼移入io/index.js中

代碼如下

// 將server作為參數(shù)傳入
module.exports = function (server) {
  var io = require('socket.io')(server);
// 用于存儲每個用戶的socket,實現(xiàn)私聊的功能
  let arrAllSocket = {}
// 穿件socket連接
  io.on('connection', (socket) => {
    console.log('連接上了');
    // console.log(socket);
    // join函數(shù) 用于用戶連接
    socket.on('join', function (obj) {
      console.log(obj.userid + 'join')
      // 保存每個用戶的連接狀態(tài) 用于私發(fā)消息
      arrAllSocket[obj.userid] = socket
    })
    // 接收前臺發(fā)送的消息 函數(shù)名為message
    socket.on('message', (data) => {
      console.log(data);
      // 將消息發(fā)送回前臺(調(diào)用前臺定義的方法) 函數(shù)名為sendMessage
      io.emit('sendMessage', data);
    });
    // 私發(fā)消息
    socket.on('sendmsg', function (data) {
      console.log(data);
      // 查詢用戶連接
      let target = arrAllSocket[data.userid]
      if (target) {
        //發(fā)送信息至指定的人
        target.emit('receivemsg', data)
      }
    })
  })
}

最后在www文件中使用如下代碼,引入文件

var io = require('../io')
io(server)

至此,聊天的基本功能實現(xiàn)。記錄一下方便以后使用。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 在 Vue 中使用 JSX 及使用它的原因淺析

    在 Vue 中使用 JSX 及使用它的原因淺析

    這篇文章主要介紹了在 Vue 中使用 JSX 及使用它的原因淺析,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-02-02
  • vue打包的時候自動將px轉(zhuǎn)成rem的操作方法

    vue打包的時候自動將px轉(zhuǎn)成rem的操作方法

    這篇文章主要介紹了vue打包的時候自動將px轉(zhuǎn)成rem的操作方法,需要的朋友可以參考下
    2018-06-06
  • Vue組件之間數(shù)據(jù)共享淺析

    Vue組件之間數(shù)據(jù)共享淺析

    本文章向大家介紹vue組件中的數(shù)據(jù)共享,主要包括vue組件中的數(shù)據(jù)共享使用實例、應(yīng)用技巧、基本知識點總結(jié)和需要注意事項,具有一定的參考價值,需要的朋友可以參考一下
    2022-11-11
  • vue2.0使用swiper組件實現(xiàn)輪播效果

    vue2.0使用swiper組件實現(xiàn)輪播效果

    這篇文章主要為大家詳細介紹了vue2.0使用swiper組件實現(xiàn)輪播效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • vue cli4下環(huán)境變量和模式示例詳解

    vue cli4下環(huán)境變量和模式示例詳解

    這篇文章主要介紹了vue cli4環(huán)境變量和模式示例詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • axios向后臺傳遞數(shù)組作為參數(shù)的方法

    axios向后臺傳遞數(shù)組作為參數(shù)的方法

    今天小編就為大家分享一篇axios向后臺傳遞數(shù)組作為參數(shù)的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • 淺析Vue.js 中的條件渲染指令

    淺析Vue.js 中的條件渲染指令

    這篇文章主要介紹了Vue.js 中的條件渲染指令,Vue.js 中的條件渲染指令可以根據(jù)表達式的值,來決定在 DOM 中是渲染還是銷毀元素或組件。本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-11-11
  • vue3中使用vuex和vue-router的詳細步驟

    vue3中使用vuex和vue-router的詳細步驟

    這篇文章主要介紹了vue3中使用vuex和vue-router的步驟,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-12-12
  • vue2.0/3.0的響應(yīng)式原理及區(qū)別淺析

    vue2.0/3.0的響應(yīng)式原理及區(qū)別淺析

    這篇文章主要給大家介紹了關(guān)于vue2.0/3.0響應(yīng)式原理及區(qū)別的相關(guān)資料,文中通過圖文介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05
  • vue 虛擬DOM的原理

    vue 虛擬DOM的原理

    這篇文章主要介紹了vue 虛擬DOM的原理,幫助大家更好的理解和學(xué)習(xí)vue,感興趣的朋友可以了解下
    2020-10-10

最新評論