前端聊天室

admin10个月前 (04-22)it知识620
<!DOCTYPE html><html><head>  <title>Socket.IO 聊天室</title>  <script src="https://cdn.socket.io/4.7.5/socket.io.min.js"></script>  <style>    .chat-box { height: 400px; border: 1px solid #ccc; overflow-y: auto; padding: 10px; }    .message { margin: 8px 0; padding: 8px; border-radius: 4px; }    .self { background: #e3f2fd; margin-left: 20%; }    .others { background: #f5f5f5; margin-right: 20%; }    #user-list { position: fixed; right: 20px; top: 20px; background: white; padding: 10px; border: 1px solid #ddd; }  </style></head><body>  <div id="user-list"></div>  <div class="chat-box" id="chatBox"></div>  <input type="text" id="messageInput" placeholder="输入消息..." style="width: 70%">  <button onclick="sendMessage()">发送</button>  <script>    // 初始化连接    const socket = io('wss://your-chat-server.com', {      auth: { userId: localStorage.getItem('userId') || `user_${Date.now()}` },      reconnectionAttempts: 3,      transports: ['websocket']    });    // 消息发送函数    function sendMessage() {      const input = document.getElementById('messageInput');      if (input.value.trim()) {        socket.emit('chatMessage', {          text: input.value,          time: new Date().toISOString()        });        input.value = '';      }    }    // 监听服务端消息    socket.on('chatMessage', (msg) => {      const isSelf = msg.userId === socket.auth.userId;      const div = document.createElement('div');      div.className = `message ${isSelf ? 'self' : 'others'}`;      div.innerHTML = `<b>${msg.nickname}</b>: ${msg.text}<br><small>${new Date(msg.time).toLocaleTimeString()}</small>`;      document.getElementById('chatBox').appendChild(div);    });    // 用户列表更新    socket.on('userListUpdate', (users) => {      document.getElementById('user-list').innerHTML =         `<h4>在线用户 (${users.length})</h4>` +         users.map(u => `<div>${u.nickname}</div>`).join('');    });    // 连接状态管理    socket.on('connect', () => {      console.log('已连接服务器');      socket.emit('joinRoom', 'public');    });    socket.on('disconnect', () => {      console.warn('连接已断开');    });    // 回车发送    document.getElementById('messageInput').addEventListener('keypress', (e) => {      if (e.key === 'Enter') sendMessage();    });  </script></body></html>

二、核心功能说明

  1. 连接配置

    • 自动生成用户 ID 并存储于 localStorage

    • 优先使用 WebSocket 协议,失败后自动重连

  2. 消息交互

    • 支持文本消息发送与格式化时间显示

    • 消息气泡区分自己/他人(CSS 样式控制)

  3. 状态管理

    • 实时更新在线用户列表

    • 自动加入默认公共聊天室 public


三、服务端需配合实现

虽然此示例为纯前端代码,但需服务端支持以下逻辑:

  1. 处理 joinRoom 事件管理房间

  2. 广播 chatMessage 到同一房间用户

  3. 维护用户连接状态并推送 userListUpdate


四、扩展建议

  1. 历史记录
    添加 localStorage 缓存最近的 100 条消息

  2. 文件传输
    通过 socket.emit('fileUpload', base64Data) 实现(需服务端支持)

  3. 心跳检测
    增加 setInterval 发送心跳包维持连接


标签: 分享IT知识

相关文章

如何学习 javascript

学习JavaScript需要以下步骤:基础语法:学习JavaScript的基础语法,包括变量、数据类型、函数、循环、条件语句等。DOM 操作:学习如何操作 DOM,例如获取和修改元素、添加和删除事件处...

超强台风的夜

夜晚,城市被一阵猛烈的台风席卷,整个世界仿佛被调成了静音模式。风声如同野兽的怒吼,呼啸着穿过大街小巷,与这座城市的一切进行着激烈的对话。雨滴如铁豆,砸在窗户上,发出沉闷的声响,宛如古老的战鼓,宣告着战...

uni-app

uni-app 是一个使用 Vue.js 开发所有前端应用的框架,开发者可以编写一套代码,然后发布到 iOS、Android、Web(响应式)、以及各种小程序(微信/支付宝/百度/头条/ QQ /钉钉...

在树林里

乡长正想坐到餐桌旁吃午饭,忽然有人来报告,说是农田巡查员抓到两个人,正等在乡长办公室里听候发落。乡长匆匆赶去,只见农田巡查员霍希多尔老人面容严肃地站在那里,一双眼睛注视着一对年纪已经不轻的城里男女,俨...

ai项目的热度

一、资本持续涌入‌初创企业受追捧‌AI编程领域出现多起高额融资案例,例如poolside获5亿美元融资,估值达30亿美元;codeium新一轮融资后估值28.5亿美元‌去中心化创意AI平台Sogni...

javascript 数据处理

JavaScript 提供了丰富的数据处理能力,涵盖数组、字符串、对象等核心数据结构的操作,以及高效的数据转换、存储和传输方法。以下是关键处理技巧和场景总结:‌一、数组处理‌‌遍历与转换‌map():...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。