socket无法服务器消息推送,socket.io

//SocketProvider.tsx

import React, { useContext, useEffect, useState } from 'react';

import { io } from 'socket.io-client';

/**

* 创建 context

*/

const SocketContext = React.createContext(null)

/**

* 调用 socket

*/

export function useSocket() {

return useContext(SocketContext)

}

/**

* 提供 socket

* @param children 子组件

*/

export function SocketProvider({ children }) {

const [socket, setSocket] = useState()

useEffect(()=>{

const newSocket = io('ws://localhost:7001')

setSocket(newSocket)

return () => newSocket.close()

}, [])

return (

<SocketContext.Provider value={socket}>

{children}

</SocketContext.Provider>

)

}

//app.tsx 中使用 SocketProvider

<SocketProvider>

{children}

</SocketProvider>

//子组件中调用 socket

const socket= useSocket()

console.log(socket)

//控制台 socket 对象

acks:

proto: Object

connected: false

disconnected: true

socket.on(‘connect’)之后才算连上吧

用 https://github.com/streamich/react-use/blob/master/docs/useAsyncFn.md 这个包一下

3431402c1bcafac7e7cfb291f3f55629.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值