前端node使用WebSocket实现实时通信例子

首先先下载ws库

npm install ws

server.js  [自定义websocket服务器,记得先用node启动]


const WebSocket = require('ws');const wss = new WebSocket.Server({ port: 8888 });wss.on('connection', function connection(ws) {console.log('Client connected');ws.on('message', function incoming(message) {console.log('Received: %s', message);// Broadcast the received message to all clientswss.clients.forEach(function each(client) {if (client !== ws && client.readyState === WebSocket.OPEN) {client.send(message);}});});
});

test.html

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Chat Application</title></head><body><div id="chat"></div><input type="text" id="messageInput" /><button onclick="sendMessage()">Send</button><script>// 简单测试const socket = new WebSocket("ws://localhost:8888");socket.onopen = () => {console.log("Connected to the server");};socket.onmessage = (event) => {const message = event.data;// 处理Blob消息if (message instanceof Blob) {const reader = new FileReader();reader.onload = function () {const text = reader.result;displayMessage(text); // 显示转换后的文本};reader.readAsText(message);} else {displayMessage(message); // 直接显示普通文本消息}};function displayMessage(message) {const chatElement = document.getElementById("chat");chatElement.innerHTML += `<p>${message}</p>`;}function sendMessage() {const messageInput = document.getElementById("messageInput");const message = messageInput.value.trim();if (message) {socket.send(message);messageInput.value = "";} else {alert("请输入消息");}}</script></body>
</html>

在两个不同的页面打开这个页面,可以发送消息,可以在另外一个页面接收并且正常显示出来

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/796570.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

华为ensp中高级acl (控制列表) 原理和配置命令 (详解)

作者主页&#xff1a;点击&#xff01; ENSP专栏&#xff1a;点击&#xff01; 创作时间&#xff1a;2024年4月6日23点18分 高级acl&#xff08;Access Control List&#xff09;是一种访问控制列表&#xff0c;可以根据数据包的源IP地址、目标IP地址、源端口、目标端口、协议…

Golang | Leetcode Golang题解之第13题罗马数字转整数

题目&#xff1a; 题解&#xff1a; var symbolValues map[byte]int{I: 1, V: 5, X: 10, L: 50, C: 100, D: 500, M: 1000}func romanToInt(s string) (ans int) {n : len(s)for i : range s {value : symbolValues[s[i]]if i < n-1 && value < symbolValues[s…

识别语序成语的简单神经网络

成语是汉语中的一种特殊表达形式&#xff0c;而语序成语则更加特殊&#xff0c;需要通过特定的语序才能表达其含义。在这篇文章中&#xff0c;我们将使用简单的神经网络来识别具有特定语序的成语。 首先&#xff0c;我们定义了一个数据集&#xff0c;其中包含了一些语序成语和…

关于 VScode, 点击文件右键或者在文件夹中没有 【 在vscode中打开选项】 解决办法

关于 VScode, 点击文件右键或者在文件夹中没有 【 在vscode中打开选项】 解决办法 段子手-168 2024-4-6 1、在任意位置创建一个文本文件。如&#xff1a;a.txt 2、复制以下代码到 a.txt 文本文件中。 &#xff08;注&#xff1a; 以 ; 开头的 , 是备注信息 , 不需要做任何修…

基于单片机高压输电线路微机保护系统设计

**单片机设计介绍&#xff0c;基于单片机高压输电线路微机保护系统设计 文章目录 一 概要二、功能设计三、 软件设计原理图 五、 程序六、 文章目录 一 概要 基于单片机高压输电线路微机保护系统设计是一个涉及电力系统继电保护的复杂工程。该系统主要利用单片机作为控制核心&…

在类Unix平台实现TCP服务端

在类Unix平台实现TCP客户端 创建服务器socket 在TCP服务器代码中&#xff0c;我们创建一个socket&#xff0c;然后调用bind函数&#xff0c;绑定到这个socket&#xff1a; // 创建本地地址配置信息struct addrinfo hints;// 清空hints的东西&#xff0c;为设置新的信息做准备…

博客部署001-centos安装docker

1、安装docker 1.1 卸载旧版本的 Docker sudo yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine1.2 设置 Docker 仓库 安装 Docker Engine 之前&#xff0c;首先需要设置…

redis 哨兵

文章目录 前言主从复制的问题怎么人工恢复故障主节点 Redis Setinel 架构使用 docker 来配置哨兵结构安装 docker编排 redis 主从节点编排 redis 哨兵节点 观察哨兵模式的作用主从切换的具体流程小结 前言 redis 主从复制模式下, 一旦主节点出现故障, 不能提供服务的时候, 就需…

C++ | Leetcode C++题解之第13题罗马数字转整数

题目&#xff1a; 题解&#xff1a; class Solution { private:unordered_map<char, int> symbolValues {{I, 1},{V, 5},{X, 10},{L, 50},{C, 100},{D, 500},{M, 1000},};public:int romanToInt(string s) {int ans 0;int n s.length();for (int i 0; i < n; i) …

jmeter下载与使用

下载 官网下载地址&#xff1a;Apache JMeter - Apache JMeter™ 由于jmeter是由java语言编写的&#xff0c;所以要先安装jdk1.8或者以上的版本 配置环境变量 配置classpath环境变量 %JMETER_HOME%\lib\ext\ApacheJMeter_core.jar;%JMETER_HOME%\lib\jorphan.jar;%JMETER_HO…

很详细的单应矩阵分解R、t过程

很详细的单应矩阵分解R、t过程 附赠自动驾驶学习资料和量产经验&#xff1a;链接 已有多种方法将单应矩阵H分解为R、t&#xff0c;在《Deeper understanding of the homography decomposition for vision-based control》一文中介绍了三种方法&#xff1a; O. Faugeras and F.…

react api:forwardRef

forwardRef 允许组件使用 ref 将 DOM 节点暴露给父组件。 ** import { forwardRef } from ‘react’; const MyInput forwardRef(function MyInput(props, ref) { // … }); 使用 forwardRef() 让组件接收 ref 并将其传递给子组件&#xff1a; forwardRef 返回一个可以在 …

Qt Creator 界面

&#x1f40c;博主主页&#xff1a;&#x1f40c;​倔强的大蜗牛&#x1f40c;​ &#x1f4da;专栏分类&#xff1a;QT❤️感谢大家点赞&#x1f44d;收藏⭐评论✍️ 目录 一、认识 Qt Creator 界面 1、总览 2、左边栏 3、代码编辑区 4、UI设计界面 5、构建区 一、认识 …

摄影杂记一

摄影小白&#xff0c;最近买了一台微单&#xff0c;型号是佳能R10&#xff0c;加上18-150套机镜头和佳能RF 50 F1.8定焦镜头。开始学习摄影。 PS&#xff1a;摄影穷三代&#xff0c;单反毁一生。嘿嘿。 一、分镜头拍摄四步提升法 B站&#xff1a;六斤 拍视频三件事&#xff1…

成都龙渊网络 UE客户端开发(20min)

自我介绍 为什么想做游戏 C熟还是C#熟 C的虚函数是什么 虚函数解决了什么问题 为什么析构函数一定要是虚函数呢 stl了解吗 说一下map的底层实现 map底层的数据结构时间复杂度是多少 unordered_map的底层实现 unordered_map底层的数据结构时间复杂度是多少 哈希冲突有…

专注项目管理的Mac工具 - Project Office Pro 最新版

Project Office Pro for Mac是一款功能强大的项目管理软件&#xff0c;旨在帮助用户更好地管理和跟踪项目进展&#xff0c;提高工作效率和质量。以下是该软件的主要功能介绍&#xff1a; 项目创建与编辑&#xff1a;用户可以根据自己的需求自定义项目计划&#xff0c;包括设置…

每天五分钟计算机视觉:模型集成和数据扩充在基准测试中的应用

本文重点 在基准测试中,模型集成和数据扩充是两个关键的技巧,它们对于提升测试的性能和准确性具有显著的影响。以下是从模型集成和数据扩充两个技巧在基准测试中的应用进行的总结。 模型集成在基准测试中的应用 在确定神经网络架构之后,我们可以独立训练几个神经网络,并…

【51单片机入门记录】RTC(实时时钟)-DS1302概述

目录 一、基于三线通信的RTC-DS1302 &#xff08;1&#xff09;简介 &#xff08;2&#xff09;特性 &#xff08;3&#xff09;引脚介绍 &#xff08;4&#xff09;控制字的格式 &#xff08;5.0&#xff09;日历时钟寄存器介绍 &#xff08;5.1&#xff09;日历时钟寄存…

4.1.k8s的pod-创建,数据持久化,网络暴露,env环境变量

目录 一、Pod介绍 二、指令创建和管理Pod 三、资源清单创建pod 1.挂载hostPath存储卷 2.NFS存储卷 所有节点安装nfs k8s3编辑NFS配置文件 k8s1&#xff0c;k8s2节点开机挂载 编辑pod资源清单&#xff0c;挂载nfs 四、pod网络暴露 1.hostNetwork使用宿主机的网络 2.…

【单片机】74HC4052电路图,单片机端口复用电路

74HC4052电路图 如下图&#xff0c;还是很好理解&#xff0c;PA9、PA10是单片机引脚。 当A和B是00&#xff0c;那么就是X-COM和0X短路&#xff0c;Y-COM和0Y短路。 当A和B是01&#xff0c;那么就是X-COM和1X短路&#xff0c;Y-COM和1Y短路。 以此类推。 74HC 工艺可以直接3.…