Nestjs与Vue实现多人聊天[简易版]

2024-03-11 13:04

本文主要是介绍Nestjs与Vue实现多人聊天[简易版],希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本项目是一个小demo,帮助各位理清一点开发思路,作为一个小参考,虽然技术栈是nodejs。但是其他语言也是相通的。

准备环境:

  • Nodejs version >=18.13.0
  • Vue3
  • Nestjs
  • soket.io

一、初始化

打开一个路径启动cmd窗口,初始化前后端项目,并安装依赖。

# 后端
nest new app
# 安装完依赖后再安装这个@nestjs/websockets包
# 前端
pnpm create vite 
# 选择vue模板,然后安装依赖,最后安装socket.io-client 和 socket.io

  

二、写逻辑

1.后端逻辑

先写后端,nestjs相关的。

  1. 首先进入demo的src目录
  2. 在src目录创建getway目录
  3. 在getway中创建两个文件,分别是gatet.module.ts和enent.gateway.ts
# gatet.module.ts
import { Module } from '@nestjs/common';
import { EventGateway } from './enent.gateway';@Module({providers: [EventGateway]
})export class GatewayModule { }
# enent.gateway.ts
// 网关文件
import { WebSocketGateway, SubscribeMessage, MessageBody, ConnectedSocket, WebSocketServer } from '@nestjs/websockets';
import { Server } from 'http';@WebSocketGateway({ cors: { origin: '*' } })
export class EventGateway {// 服务端@WebSocketServer()serve: Server;// 订阅消息@SubscribeMessage('sayMessage')handleMessage(@MessageBody() body: any, @ConnectedSocket() client: any) {// 监听一个自定义事件来发布消息// client.emit('onMessage')const { origin } = client.handshake.headersthis.serve.emit('onMessage', {time: new Date().toLocaleString(),msg: body,ip: origin})}
}

最后一步就是app.modules.ts中imports导入 GatewayModule 

import { Module } from '@nestjs/common';
import { AppController } from './app.controller';
import { AppService } from './app.service';
import { GatewayModule } from './getway/gatet.module';@Module({imports: [GatewayModule],controllers: [AppController],providers: [AppService],
})
export class AppModule { }

2.前端逻辑

 

<template><div><ul><li v-for="(item, index) in list" :key="index"><span style="color:red;font-size: 0.9vw;">IP:{{ showIp(item.ip) }}</span>&nbsp;&nbsp;<span>{{ item.msg }}</span>&nbsp;&nbsp;<span style="color:#888;font-size: 0.9vw;">{{ item.time }}</span></li></ul><input type="text" v-model="value"><button @click="handleSendMsg">发送消息</button></div>
</template><script setup>
import { io } from "socket.io-client";
import { ref, onMounted, onUnmounted, computed, watch } from 'vue'/*** @name 服务器地址*/
const socket = io(`http://localhost:3000`)/*** @name 消息列表*/
const list = ref([])/*** @name 输入的信息*/
const value = ref('')/*** @name 连接状态*/
const inside = ref(false)// 发送消息
const handleSendMsg = () => {if (value.value != '') {socket.emit('sayMessage', value.value, e => { })value.value = ''} else {alert('你输入的信息不能为空')}
}// 连接成功
socket.on('connect', () => {inside.value = true
})
// 断开连接
socket.on('disconnect', () => {inside.value = false
})socket.on('foo', (...args) => {console.log("foo", args);
})socket.on('bar', (...args) => {console.log("bar", args);
})onMounted(() => {// 监听接收消息socket.on('onMessage', e => {list.value.push(e)})
})onUnmounted(() => {// 断开连接socket.disconnect()
})</ script>

都比较简单,想了解具体用发,可以去官网:https://socket.io/zh-CN/ 

这篇关于Nestjs与Vue实现多人聊天[简易版]的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

Java 压缩包解压实现代码

《Java压缩包解压实现代码》Java标准库(JavaSE)提供了对ZIP格式的原生支持,通过java.util.zip包中的类来实现压缩和解压功能,本文将重点介绍如何使用Java来解压ZIP或RA... 目录一、解压压缩包1.zip解压代码实现:2.rar解压代码实现:3.调用解压方法:二、注意事项三、总

NGINX 配置内网访问的实现步骤

《NGINX配置内网访问的实现步骤》本文主要介绍了NGINX配置内网访问的实现步骤,Nginx的geo模块限制域名访问权限,仅允许内网/办公室IP访问,具有一定的参考价值,感兴趣的可以了解一下... 目录需求1. geo 模块配置2. 访问控制判断3. 错误页面配置4. 一个完整的配置参考文档需求我们有一

Linux实现简易版Shell的代码详解

《Linux实现简易版Shell的代码详解》本篇文章,我们将一起踏上一段有趣的旅程,仿照CentOS–Bash的工作流程,实现一个功能虽然简单,但足以让你深刻理解Shell工作原理的迷你Sh... 目录一、程序流程分析二、代码实现1. 打印命令行提示符2. 获取用户输入的命令行3. 命令行解析4. 执行命令

基于MongoDB实现文件的分布式存储

《基于MongoDB实现文件的分布式存储》分布式文件存储的方案有很多,今天分享一个基于mongodb数据库来实现文件的存储,mongodb支持分布式部署,以此来实现文件的分布式存储,需要的朋友可以参考... 目录一、引言二、GridFS 原理剖析三、Spring Boot 集成 GridFS3.1 添加依赖

利用Python实现Excel文件智能合并工具

《利用Python实现Excel文件智能合并工具》有时候,我们需要将多个Excel文件按照特定顺序合并成一个文件,这样可以更方便地进行后续的数据处理和分析,下面我们看看如何使用Python实现Exce... 目录运行结果为什么需要这个工具技术实现工具的核心功能代码解析使用示例工具优化与扩展有时候,我们需要将

Python+PyQt5实现文件夹结构映射工具

《Python+PyQt5实现文件夹结构映射工具》在日常工作中,我们经常需要对文件夹结构进行复制和备份,本文将带来一款基于PyQt5开发的文件夹结构映射工具,感兴趣的小伙伴可以跟随小编一起学习一下... 目录概述功能亮点展示效果软件使用步骤代码解析1. 主窗口设计(FolderCopyApp)2. 拖拽路径

Spring AI 实现 STDIO和SSE MCP Server的过程详解

《SpringAI实现STDIO和SSEMCPServer的过程详解》STDIO方式是基于进程间通信,MCPClient和MCPServer运行在同一主机,主要用于本地集成、命令行工具等场景... 目录Spring AI 实现 STDIO和SSE MCP Server1.新建Spring Boot项目2.a

Spring Boot拦截器Interceptor与过滤器Filter深度解析(区别、实现与实战指南)

《SpringBoot拦截器Interceptor与过滤器Filter深度解析(区别、实现与实战指南)》:本文主要介绍SpringBoot拦截器Interceptor与过滤器Filter深度解析... 目录Spring Boot拦截器(Interceptor)与过滤器(Filter)深度解析:区别、实现与实

C#实现访问远程硬盘的图文教程

《C#实现访问远程硬盘的图文教程》在现实场景中,我们经常用到远程桌面功能,而在某些场景下,我们需要使用类似的远程硬盘功能,这样能非常方便地操作对方电脑磁盘的目录、以及传送文件,这次我们将给出一个完整的... 目录引言一. 远程硬盘功能展示二. 远程硬盘代码实现1. 底层业务通信实现2. UI 实现三. De

SpringBoot后端实现小程序微信登录功能实现

《SpringBoot后端实现小程序微信登录功能实现》微信小程序登录是开发者通过微信提供的身份验证机制,获取用户唯一标识(openid)和会话密钥(session_key)的过程,这篇文章给大家介绍S... 目录SpringBoot实现微信小程序登录简介SpringBoot后端实现微信登录SpringBoo