当前位置: 首页 > news >正文

html写一个向flask_socketio发送消息和接收消息并显示在页面上

以下是一个简单的HTML页面,它包含一个输入框、一个发送按钮和一个显示区域。用户可以在输入框中输入消息,点击发送按钮,然后这个消息会被发送到 Flask-SocketIO 服务器。当服务器回应消息时,它会在页面的显示区域显示出来。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Flask-SocketIO Chat</title><!-- Import the Socket.IO client library --><script src="https://cdnjs.cloudflare.com/ajax/libs/socket.io/4.0.1/socket.io.js"></script><script type="text/javascript">document.addEventListener("DOMContentLoaded", function() {const socket = io.connect('http://localhost:5000');const messagesDiv = document.getElementById('messages');const inputElem = document.getElementById('messageInput');const buttonElem = document.getElementById('sendButton');// Listen for a 'response' event from the serversocket.on('response', function(msg) {const pElem = document.createElement('p');pElem.innerText = msg.data;messagesDiv.appendChild(pElem);});// Send the input message to the server on button clickbuttonElem.addEventListener('click', function() {const message = inputElem.value;socket.emit('send_message', {data: message});inputElem.value = ''; // Clear the input});});</script>
</head>
<body><h1>Flask-SocketIO Chat</h1><input type="text" id="messageInput" placeholder="Type your message here..."><button id="sendButton">Send</button><div id="messages"></div>
</body>
</html>

此外,Flask-SocketIO 服务器端代码可以处理客户端发送的 send_message 事件,并返回一个 response 事件。例如:

from flask import Flask
from flask_socketio import SocketIOapp = Flask(__name__)
socketio = SocketIO(app)@socketio.on('send_message')
def handle_message(message):print('Received message:', message['data'])socketio.emit('response', {'data': 'Server received: ' + message['data']})if __name__ == '__main__':socketio.run(app, debug=True)

当用户在HTML页面上输入消息并点击发送按钮时,消息会被发送到 Flask-SocketIO 服务器。服务器接收到消息后,会发送一个回应,该回应将在页面上显示。

http://www.lryc.cn/news/139168.html

相关文章:

  • C#使用.Net Core进行跨平台开发
  • Java“牵手”天猫店铺所有商品API接口数据,通过店铺ID获取整店商品详情数据,天猫API申请指南
  • php输入post过滤函数,入库出库,显示
  • matlab-对数据集加噪声并实现tsne可视化
  • 【BASH】回顾与知识点梳理(三十八)
  • Sql注入攻击的三种方式
  • dockerfile部署前端vue打包的dist文件实战
  • [技术杂谈]MobaXterm中文乱码编码问题一种解决方法
  • mac os M1 安装并启动 postgreSQL 的问题
  • 如何使用Wireshark进行网络流量分析?
  • 抖音web主页视频爬虫
  • 常用的jar包【maven坐标格式】
  • 【分布式】VMware FT概要
  • 江西南昌电气机械三维测量仪机械零件3d扫描-CASAIM中科广电
  • MySQL三大日志(binlog、redo log和undo log)详解
  • 七大排序算法详解
  • [docker][WARNING]: Empty continuation line found in:
  • 探工业互联网的下一站!腾讯云助力智造升级
  • SpringBoot上传文件的实现与优化
  • 学习python可以做什么?有前景么
  • 还不知道怎么提示LLM?ChatGPT提示入门
  • 反射机制-体会反射的动态性案例(尚硅谷Java学习笔记)
  • uniapp离线打包apk - Android Studio
  • cuda面试准备(一),架构调试
  • docker containers logs清理
  • Ubuntu安装RabbitMQ
  • Vue3获取当前环境信息
  • Linux 系统 diff 文件比较命令详解
  • 【负载均衡】Nacos简单入门
  • 实验一 ubuntu 网络环境配置