| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> JavaScript知识库 -> node.js + websocket实现一个简单的聊天室 -> 正文阅读 |
|
[JavaScript知识库]node.js + websocket实现一个简单的聊天室 |
一、websocket是什么?WebSocket是一种在单个TCP连接上进行全双工通信的协议。WebSocket使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据。在WebSocket API中,浏览器和服务器只需要完成一次握手,两者之间就直接可以创建持久性的连接,并进行双向数据传输。 二、实现过程1.前端界面显示部分<!DOCTYPE?html> <html?lang="en"> ??<head> ????<meta?charset="UTF-8"?/> ????<meta?name="viewport"?content="width=device-width,?initial-scale=1.0"?/> ????<title>Document</title> ??</head> ??<body> ????<input?type="text"?name=""?id=""?/> ????<button>发送消息</button> ????<div?class="box2"></div> ????<script> ??????const?div?=?document.querySelector('div'); ??????const?input?=?document.querySelector('input'); ??????const?btn?=?document.querySelector('button'); ??????const?socket?=?new?WebSocket('ws://localhost:8080'); ??????const?ENTER_TYPE?=?0; ??????const?OUT_TYPE?=?1; ??????const?OTHER_TYPE?=?2; ??????//?open:当和websocket服务连接成功时的时候触发 ??????socket.addEventListener('open',?function?()?{ ????????div.innerHTML?=?'服务器连接成功'; ??????}); ??????//?点击按钮给服务器发送消息 ??????btn.addEventListener('click',?()?=>?{ ????????socket.send(input.value); ????????input.value?=?''; ??????}); ??????//message:接受到websocketf服务返回的数据 ??????socket.addEventListener('message',?(e)?=>?{ ????????const?dv?=?document.createElement('div'); ????????const?data?=?JSON.parse(e.data); ????????dv.innerText?=?data.userName; ????????if?(data.type?==?ENTER_TYPE)?{ ??????????dv.style.color?=?'green'; ????????}?else?if?(data.type?==?OUT_TYPE)?{ ??????????dv.style.color?=?'red'; ????????}?else?{ ??????????dv.style.color?=?''; ????????} ????????div.appendChild(dv); ??????}); ??????//?close:当和websocket服务关闭时的时候触发 ??????socket.addEventListener('close',?()?=>?{ ????????div.innerText?=?'服务器已关闭'; ??????}); ????</script> ??</body> </html> 2. node.js实现部分const?websocket?=?require('nodejs-websocket'); const?ENTER_TYPE?=?0; const?OUT_TYPE?=?1; const?OTHER_TYPE?=?2; let?count?=?0; //创建服务器 const?server?=?websocket.createServer((connect)?=>?{ ??//每个用户进来就加一 ??count++; ??//添加用户名 ??connect.userName?=?`用户${count}`; ??//服务器连接时直接返回数据给浏览器显示:告诉所有人,有人进入聊天室 ??broadcast({ ????type:?ENTER_TYPE, ????userName:?`${ ??????connect.userName ????}进入聊天室?----?${new?Date().toLocaleDateString()}`, ????time:?new?Date().toLocaleDateString()?//toLocaleDateString?转成当前本地时间 ??}); ??//接受到浏览器的发送过来的数据,处理后再返回给浏览器 ??connect.on('text',?(data)?=>?{ ????//接收到用户消息的时候,告诉所有用户,发送的消息内容是什么 ????//?broadcast(data); ????broadcast({ ??????type:?OUT_TYPE, ??????userName:?data, ??????time:?new?Date().toLocaleDateString()?//toLocaleDateString?转成当前本地时间 ????}); ??}); ??//连接关闭时,直接返回数据给浏览器:告诉所有人,有人离开入聊天室 ??connect.on('close',?(data)?=>?{ ????count--; ????//?broadcast(`${connect.userName}已经离开聊天室`); ????broadcast({ ??????type:?OTHER_TYPE, ??????userName:?`${ ????????connect.userName ??????}已经离开聊天室----?${new?Date().toLocaleDateString()}`, ??????time:?new?Date().toLocaleDateString() ????}); ??}); ??//连接异常 ??connect.on('error',?(data)?=>?{ ????console.log('连接异常'); ??}); }); //?广播,给所有的用户发消息 function?broadcast(msg)?{ ??//server.connections?表示所有用户 ??server.connections.forEach((element)?=>?{ ????element.send(JSON.stringify(msg)); ??}); } server.listen(8080,?()?=>?{ ??console.log('服务器启动完毕'); }); |
|
JavaScript知识库 最新文章 |
ES6的相关知识点 |
react 函数式组件 & react其他一些总结 |
Vue基础超详细 |
前端JS也可以连点成线(Vue中运用 AntVG6) |
Vue事件处理的基本使用 |
Vue后台项目的记录 (一) |
前后端分离vue跨域,devServer配置proxy代理 |
TypeScript |
初识vuex |
vue项目安装包指令收集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
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/14 18:10:33- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |