了解如何建立实时聊天

了解如何建立实时聊天

在本教程中,我们将指导您使用 superviz 构建实时聊天应用程序。实时聊天是现代 web 应用程序的一项重要功能,它使用户能够即时相互通信。无论您是在构建协作平台、客户支持工具还是社交网站,添加实时聊天都可以增强用户交互和参与度。

我们将演示如何设置一个简单的聊天界面,参与者可以在其中实时发送和接收消息。在本教程结束时,您将拥有一个功能齐全的聊天应用程序,您可以扩展和自定义该应用程序以满足您的特定需求。

让我们开始吧!

先决条件

要学习本教程,您将需要一个 superviz 帐户和一个开发者令牌。如果您已经拥有帐户和开发者令牌,则可以继续下一步。

创建一个帐户

要创建帐户,请访问 https://dashboard.superviz.com/register 并使用 google 或电子邮件/密码创建帐户。请务必注意,使用电子邮件/密码时,您将收到一个确认链接,您需要点击该链接来验证您的帐户。

检索开发者令牌

要使用 sdk,您需要提供开发者令牌,因为此令牌对于将 sdk 请求与您的帐户关联起来至关重要。您可以从仪表板检索开发和生产 superviz 令牌..

复制并保存开发者令牌,因为您在本教程的后续步骤中将需要它。

第 1 步:设置您的 react 应用程序

首先,您需要建立一个新的 react 项目,我们将在其中集成 superviz 进行实时通信。

1. 创建一个新的react项目

首先,使用 create react app with typescript 创建一个新的 react 应用程序。

npm create vite@latest realtime-chat -- --template react-tscd realtime-chat

2.安装所需的库

接下来,为我们的项目安装必要的库:

npm install @superviz/sdk uuid react-icons

@superviz/sdk: 用于集成实时通信功能。 uuid: 用于生成唯一标识符的库,可用于创建唯一的参与者 id。 react-icons: 用于在 react 应用程序中包含图标的库,此处用于发送按钮图标。

3. 配置顺风

在本教程中,我们将使用 tailwind css 框架。首先,安装 tailwind 软件包。

npm install -d tailwindcss postcss autoprefixernpx tailwindcss init -p

然后我们需要配置模板路径。在项目根目录中打开 tailwind.config.js 并插入以下代码。

/** @type {import('tailwindcss').config} */ export default { content: [ "./index.html", "./src/**/*.{js,ts,jsx,tsx}", ], theme: { extend: {}, }, plugins: [], }

然后我们需要将 tailwind 指令添加到全局 css 文件中。 (src/index.css)

@tailwind base;@tailwind components;@tailwind utilities;

4. 设置环境变量

在项目根目录中创建一个 .env 文件并添加 superviz 开发人员密钥。此密钥将用于通过 superviz 服务验证您的应用程序。

vite_superviz_api_key=your_superviz_developer_key

第 2 步:实现主应用程序

在这一步中,我们将实现主要应用程序逻辑来初始化 superviz 并处理实时聊天消息。

1. 实现app组件

打开 src/app.tsx 并使用 superviz 设置主应用程序组件来管理聊天功能。

import  { v4 as generateid }  from  'uuid';import  { usecallback, useeffect, usestate, useref }  from  "react";import  supervizroom,  {  realtime,  realtimecomponentevent,  realtimemessage  }  from  '@superviz/sdk';import  {  iomdsend  }  from  "react-icons/io";

说明:

导入: 从 react、superviz、uuid 和 react icons 导入必要的组件,用于管理状态、初始化 superviz 和渲染聊天界面。

2. 定义常量

定义 api 密钥、房间 id 和消息类型的常量。

const apikey = import.meta.env.vite_superviz_api_key as string; const room_id = 'realtime-chat'; type message = realtimemessage & {     data: {         participantname: string;         message: string;     } }

说明:

apikey: 从环境变量中检索 superviz api 密钥。 room_id: 定义 superviz 会话的房间 id。 消息: 扩展 realtimemessage 以包含参与者姓名和消息内容的类型。

3. 创建应用程序组件

设置主 app 组件并初始化状态变量和引用。

export default function app() {     const participant = useref({         id: generateid(),         name: 'participant-name',     });     const channel = useref(null);     const [initialized, setinitialized] = usestate(false);     const [message, setmessage] = usestate('');     const [messages, setmessages] = usestate([]);

说明:

参与者: 使用 useref 存储当前参与者的 id 和名称。 频道: 存储对实时通信频道的引用。 已初始化: 跟踪 superviz 是否已初始化。 消息&消息:管理当前输入的消息和聊天消息列表。

4. 初始化superviz

创建一个函数来初始化 superviz 并设置实时消息处理。

const initialize = usecallback(async () => {     if (initialized) return;     const superviz = await supervizroom(apikey, {         roomid: room_id,         participant: participant.current,         group: {             id: 'realtime-chat',             name: 'realtime-chat',         },     });     const realtime = new realtime();     superviz.addcomponent(realtime);     setinitialized(true);     realtime.subscribe(realtimecomponentevent.realtime_state_changed, () => {         channel.current = realtime.connect('message-topic');         channel.current.subscribe('message', (data: message) => {             setmessages((prev) => [...prev, data].sort((a, b) => a.timestamp - b.timestamp));        });     }); }, [initialized]);

说明:

initialize: 初始化 superviz,设置实时组件,订阅消息主题。 实时: 处理聊天的实时通信。 channel.current: 存储与“消息主题”通道的连接,消息在该通道中发布和订阅。

5. 处理发送消息

创建一个向聊天发送消息的函数。

const sendmessage = usecallback(() => {     if (!channel.current) return;     channel.current.publish('message', {         message,         participantname: participant.current!.name,     });     setmessage(''); }, [message]);

说明:

sendmessage: 将当前消息发布到“message-topic”频道并重置消息输入。

6.使用effect hook进行初始化

使用 useeffect 钩子在组件挂载时触发初始化函数。

useeffect(()  =>  {  initialize();},  [initialize]);

说明:

useeffect: 组件挂载时调用一次初始化函数,设置 superviz 环境和实时聊天。

第三步:渲染聊天界面

最后返回用于渲染聊天界面的jsx结构。

return (     

realtime chat

{ messages.map((message) => (
{message.participantid === participant.current!.id ? 'you' : message.data.participantname}
{message.data.message}
)) }
setmessage(e.target.value)} />
)

说明:

聊天界面: 显示聊天消息和带有发送按钮的输入字段。根据消息是由当前参与者还是其他人发送,消息的样式有所不同。

第 4 步:了解项目结构

以下是项目结构如何支持实时聊天应用程序的快速概述:

app.tsx: 初始化 superviz 并设置实时聊天功能。 处理实时发送和接收聊天消息。 聊天界面: 以聊天气泡的形式显示消息,并提供输入字段和发送按钮供用户发送消息。 实时通信: 使用 superviz 管理参与者之间的实时通信。

第 5 步:运行应用程序

1.启动react应用程序

要运行您的应用程序,请在项目目录中使用以下命令:

npm run dev

此命令将启动开发服务器并在默认 web 浏览器中打开您的应用程序。您可以与聊天界面互动,并在其他参与者加入时实时查看消息。

2. 测试应用程序

实时消息传递: 在多个浏览器窗口或选项卡中打开应用程序以模拟多个参与者并验证消息是否实时发送和接收。 协作交互: 通过发送消息并观察所有参与者的聊天更新情况来测试应用程序的响应能力。

概括

在本教程中,我们使用 superviz 构建了一个实时聊天应用程序。我们配置了一个 react 应用程序来处理实时消息传递,使多个用户能够无缝通信。此设置可以扩展和定制,以适应需要实时通信的各种场景。

请随意探索 github 存储库中的完整代码和更多示例以了解更多详细信息。

以上就是了解如何建立实时聊天的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1493127.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 15:25:37
下一篇 2025年12月19日 15:25:46

相关推荐

  • 在Node.js环境中操作CSS规则的两种主要方法

    在node.js中直接访问css规则类似于浏览器dom操作是不可能的,因为node.js没有内置dom环境。然而,开发者可以通过两种主要方式实现这一目标:一是利用`jsdom`库模拟浏览器dom环境来访问`document.stylesheets`和`cssrules`;二是通过`css-tree`…

    2025年12月20日
    000
  • 在Google Pie Chart切片中添加百分比符号的专业指南

    在数据可视化中,尤其是在使用饼图(pie chart)展示比例数据时,直观地显示百分比是一个常见的需求。google charts是一个功能强大的javascript库,用于创建各种交互式图表。然而,直接在数据源(如sql查询)中拼接百分比符号,并不能被google charts正确解析为数值进行图…

    好文分享 2025年12月20日
    000
  • 如何在不暴露密钥的情况下,在客户端创建 Stripe Payment Link

    本文介绍了在纯静态网站环境下,如何利用 Stripe Payment Link 实现商品售卖,并着重讨论了在不暴露 Stripe 密钥的前提下,客户端创建 Payment Link 的可行性。分析了直接在客户端使用密钥的风险,并提出了预先生成 Payment Link 或使用后端服务动态生成 Pay…

    2025年12月20日
    000
  • Node.js环境中CSS规则操作策略:DOM模拟与AST解析

    在node.js环境中处理css规则时,由于缺乏浏览器dom,开发者面临挑战。本文将介绍两种主要策略:利用jsdom模拟浏览器dom环境以访问`document.stylesheets`等api,或采用csstree等工具解析css为抽象语法树(ast)进行高效、精细的程序化操作。这两种方法都能有效…

    2025年12月20日
    000
  • WordPress中JavaScript类管理与视差效果的性能优化实践

    本文深入探讨了在wordpress网站中有效集成和优化javascript类的方法,特别关注了视差动画的实现。我们将学习如何重构javascript类以实现关注点分离,利用工厂函数模式管理类实例,并针对滚动事件进行性能优化,以确保动画流畅且网站响应迅速。 在WordPress环境中开发动态交互功能,…

    2025年12月20日
    000
  • Node.js中访问和修改CSS规则:JSDOM与CSSTree实战指南

    在node.js环境中,直接访问和修改css规则面临缺乏浏览器dom的挑战。本文将介绍两种主要解决方案:一是利用jsdom模拟浏览器dom环境,实现document.stylesheets等操作;二是采用csstree解析css为抽象语法树(ast),进行精细化的结构化操作和转换。通过这两种方法,开…

    2025年12月20日
    000
  • Bootstrap List Group嵌套链接点击失效问题解决方案

    本文旨在解决Bootstrap List Group中嵌套链接在首次点击后失效的问题。通过JavaScript代码,移除激活状态,确保嵌套链接在每次点击父级选项卡后都能正常工作,从而实现预期的页面导航功能。本文提供了详细的代码示例和解释,帮助开发者快速定位和解决类似问题。 在使用Bootstrap的…

    2025年12月20日
    000
  • styled-jsx 父组件样式应用于子元素的实践指南

    本文深入探讨了在 `styled-jsx` 中父组件样式无法直接作用于通过 `children` prop 渲染的子元素的问题。我们将解释 `styled-jsx` 的默认作用域机制,并提供一个实用的解决方案:利用 `:global()` 伪选择器来精确地将父组件定义的样式应用到其子元素上,从而实现…

    2025年12月20日
    000
  • 深入理解 npm-remote-ls:排查依赖缺失问题与版本管理

    在使用 `npm-remote-ls` 检查 node.js 模块的远程依赖时,可能会遇到某些预期依赖未显示的问题。这通常是由于指定了错误的模块版本,或者混淆了 git 仓库的最新状态与已发布 npm 包的特定版本所致。本文将深入探讨这一常见问题,并提供准确获取模块依赖列表的方法,强调版本管理在 n…

    2025年12月20日
    000
  • 解决 Bootstrap List Group 嵌套链接点击后失效的问题

    本文旨在解决Bootstrap List Group嵌套链接在初次点击后失效的问题。通过JavaScript代码,动态移除已激活链接的`active`类,确保每次点击父级Tab时,子链接都能正确响应,实现预期的页面导航效果。本文提供详细的代码示例和解释,帮助开发者理解并解决类似问题。 在使用 Boo…

    2025年12月20日
    000
  • 在Node.js环境中高效操作CSS规则:告别DOM限制

    在Node.js构建流程中处理CSS时,传统的浏览器DOM方法不再适用。本文将深入探讨两种主要策略:利用JSDOM模拟浏览器DOM环境以访问`cssRules`,以及通过CSSTree库解析CSS为抽象语法树(AST)进行更精细的程序化操作。我们将提供详细示例,帮助开发者在Node.js中实现复杂的…

    2025年12月20日
    000
  • 在 styled-jsx 中如何将父组件样式应用于子组件

    本文详细探讨了在 `styled-jsx` 中,父组件如何将其定义的样式应用于通过 `children` prop 传入的子元素。针对 `styled-jsx` 默认的样式作用域限制,文章重点介绍了 `:global()` 选择器的使用方法,并通过实际代码示例,演示了如何实现父组件对子元素的样式控制…

    2025年12月20日
    000
  • 在 Google 饼图中显示百分比值

    本文详细介绍了如何在 Google 饼图的切片上正确显示百分比符号。通过利用 `google.visualization.NumberFormat` 类,您可以为饼图数据添加自定义后缀(如百分比符号)并控制小数位数,从而提升数据展示的专业性和可读性。教程涵盖了主饼图和弹出式子饼图的格式化方法,并提供…

    2025年12月20日
    000
  • JavaScript性能优化核心技术

    答案:JavaScript性能优化需减少重排重绘,批量操作DOM,用类切换替代内联样式,避免同步布局;采用事件委托降低内存开销;通过防抖节流控制高频事件;及时解绑事件、清除定时器以优化内存;利用Web Workers处理密集计算,保持主线程流畅。 JavaScript性能优化的核心在于减少执行时间、…

    2025年12月20日
    000
  • 在React项目中正确加载本地图片资源:以Swiper背景图为例

    本文旨在解决react应用中,特别是swiper组件作为背景图时,本地图片无法正确显示的问题。核心解决方案是利用react项目的public文件夹管理静态资源,并通过相对路径或process.env.public_url构建正确的图片访问路径,确保图片资源能够被浏览器成功加载并渲染。 引言:Reac…

    2025年12月20日 好文分享
    000
  • Google Charts:如何在饼图切片中优雅地显示百分比符号

    本文详细介绍了在google charts饼图中为切片值添加百分比符号的专业方法。通过利用`google.visualization.numberformat`类,开发者可以精确控制数值的显示格式,包括添加百分比后缀和指定小数位数,从而确保图表数据展示的清晰性和专业性。 在数据可视化中,饼图常用于展…

    2025年12月20日
    000
  • React Swiper 组件背景图片无法显示问题解决方案

    本文针对 React 项目中使用 Swiper 组件时,背景图片无法从本地目录加载显示的问题,提供了详细的解决方案。通过将图片资源放置于 `public` 目录下,并使用正确的相对路径或 `PUBLIC_URL` 环境变量,可以有效解决该问题,确保背景图片能够正确加载并显示在 Swiper 组件中。…

    2025年12月20日 好文分享
    000
  • 如何将一组数值规范化到0-1范围:基于最大值的权重计算

    本教程详细介绍了如何将一组数值规范化到0-1的范围,其中最小值映射到0(或接近0),最大值映射到1。通过将每个数值除以集合中的最大值来实现,这在需要根据相对大小而非总和百分比来表示数据(如css透明度)时非常有用。 引言:理解数值规范化需求 在数据处理和前端开发中,我们经常需要将一组原始数值转换到一…

    2025年12月20日
    000
  • 在WordPress中集成JavaScript类实现视差效果及性能优化指南

    本文详细探讨了在wordpress网站中集成javascript类以实现动态视差效果的有效方法。核心内容包括重构javascript类以实现职责分离,利用工厂函数模式高效创建和管理类实例,以及对滚动事件监听器进行性能优化,以确保网站的流畅性和响应速度。通过遵循这些最佳实践,开发者可以构建出高性能且易…

    2025年12月20日
    000
  • Bootstrap List Group嵌套链接点击后失效的解决方案

    本文旨在解决Bootstrap List Group中嵌套链接在首次点击后失效的问题。通过分析问题的根本原因,即Tab页激活状态的保持,提供了一种使用JavaScript动态移除`active`类的方法,确保嵌套链接每次点击都能正确响应,实现预期的页面导航功能。 在使用Bootstrap构建Web应…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信