IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> react+socket.io+node实现聊天室 -> 正文阅读

[JavaScript知识库]react+socket.io+node实现聊天室

socket.io

官网地址:https://socket.io/docs/v4/

1、服务器端

1.1、安装

socket.io v4.x版本 至少需要 Nodev10

1.2、下载

npm install socket.io

1.3、使用

1.3.1、启动端口

这里使用的是express

var express = require('express');//引用express
var app = express();//创建express实例

var server = app.listen(9999, function () {//应用启动端口为9999
  var host = server.address().address;
  var port = server.address().port;
  console.log("访问地址为", host, port)
});

const socketIo = require('socket.io')(server, { cors: true });

1.3.2、socketIo监听
let users = []
//监听connection(用户连接)事件,socket为用户连接的实例
socketIo.on('connection',(socket)=>{
  socket.on('disconnect',()=>{
    console.log("用户"+socket.id+"断开连接");
    users = users.filter(item=> item.socketId !== socket.id)
  });
  
  // 监听客户端连接事件
  socket.on('client_online', data => {
    const { nickName, id } = data
    const userInfo = {
      nickName,
      socketId:socket.id,
      id
    }
    users.push(userInfo)
    socketIo.emit('server_online',users);
 })
 
 socket.on('client_msg',(data)=>{
    //监听msg事件(这个是自定义的事件)
    // type 1代表左侧消息,2代表右侧消息
    const { msg, nickName, roomId, userId } = data
    const params = {
      msg,
      nickName,
      times:moment(new Date().getTime()).format('YYYY-MM-DD HH:mm:ss'),
      userId,
    }
    
    const leftMessage = { ...params, type:1 }
    const rightMessage = { ...params, type:2 }
    
    // 向其他人发送消息
    socket.broadcast.emit('server_msg',leftMessage);
    // 向当前发送者返回消息
    socket.emit('server_msg',rightMessage);
  })
})

socket.id自动生成,每次连接都是新的id,这里通过监听client_online事件,收集客户端传入的数据data,
通过client_message

data:{ 
    id:number;
    nickName:string;
}

2、客户端

2.1、安装

socket.io v4.x版本 至少需要 Nodev10

2.2、下载

npm install socket.io-client

2.3、使用

import io from 'socket.io-client'
const socket = io('ws://localhost:9999')

socket.emit('client_online', {
  nickName,
  id:userId,
})


通过client_online自定义事件,向服务端传输当前用户信息,服务端保存当前连接数量及用户

socket.emit('client_msg', { 
  msg,
  nickName,
  userId
})

通过client_msg自定义事件,向服务端发送聊天信息

socket.on('server_msg', (data) => {
  const { chatMsg } = this.state
  
  const newChatMsg = chatMsg.concat(data)
  this.setState({
    chatMsg:newChatMsg
  })
});

通过监听server_msg,获取服务端返回的消息,并保存

3、截图

3.1最终实现截图

在这里插入图片描述

3.3网址

该网址不保存聊天记录、不需要注册登录
http://47.102.121.156:8092/chat

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-09-15 01:54:55  更:2022-09-15 01:55:46 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 15:00:31-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码