在 React Context 中实现 Socket.io 是个好习惯吗?

问题描述 投票:0回答:1

我需要应用程序中的所有组件都可以访问我的套接字。我最初的想法是在反应上下文中实现套接字,然后将整个应用程序包装在我创建的套接字上下文中。我只是想知道这是否是一个好方法,或者是否有更好的实现?

这就是我到目前为止所拥有的...

import React, { createContext, useContext } from "react";
import { io, Socket } from "socket.io-client";

const SocketContext = createContext<Socket | null>(null);

export const useSocket = () => {
  return useContext(SocketContext);
};

export const SocketProvider = ({ children }: { children: React.ReactNode }) => {
  const socket = io("http://localhost:3000");
  return (
    <SocketContext.Provider value={socket}>{children}</SocketContext.Provider>
  );
};
reactjs typescript react-native websocket socket.io
1个回答
0
投票

是的,使用 React 上下文来管理套接字并包装整个应用程序是使套接字可跨组件访问的合适方法。

© www.soinside.com 2019 - 2024. All rights reserved.