React+Websocket简单实例

简介: 最近很多项目需要用到websocket,经过智能客服项目沉淀了一个简单的实例,以后可以直接用。有需要指教的地方可以联系我。

页面:

import React,{useEffect} from 'react'
import { PubSub } from 'pubsub-js';
import {createWebSocket,closeWebSocket,websocket} from './websocket';

function Ws(){
    
useEffect(() => {
    let url="ws://123.207.136.134:9010/ajaxchattest";//服务端连接的url
        createWebSocket(url)
        let messageSocket=null;
        messageSocket = PubSub.subscribe('message',getMsg)
        //在组件卸载的时候,关闭连接
         return ()=>{
            PubSub.unsubscribe(messageSocket); 
            closeWebSocket();
        }
}, []);

const sendMsg=()=>{
    let msg='发送消息'
    websocket&&websocket.send(msg)
    console.log('ws发送')
}

const getMsg=(topic,message)=>{
    console.log('ws获取:',message)
}
    return(
        <div>
            <button onClick={sendMsg}>发送消息</button>
            <button onClick={closeWebSocket}>关闭连接</button>
        </div>
    )
}

export default Ws

Websocket JS文件:

import { PubSub } from 'pubsub-js';
let websocket,
  lockReconnect = false;
let createWebSocket = (url) => {
  websocket = new WebSocket(url);
    console.log('ws connect')
  websocket.onopen = function() {
    console.log('ws open')
    heartCheck.reset().start();
  };
  websocket.onerror = function() {
    reconnect(url);
  };
  websocket.onclose = function(e) {
    heartCheck.reset()
    console.log('ws closed: ' + e.code + ' ' + e.reason + ' ' + e.wasClean);
  };
  websocket.onmessage = function(event) {
    lockReconnect = true;
    //event 为服务端传输的消息,在这里可以处理
    let data=event.data;//把获取到的消息处理成字典,方便后期使用
    PubSub.publish('message',data); //发布接收到的消息 'message' 为发布消息的名称,data 为发布的消息
  
  };
};
let reconnect = (url) => {
  if (lockReconnect) return;
  // 没连接上会一直重连,设置延迟避免请求过多
  setTimeout(function() {
    createWebSocket(url);
    lockReconnect = false;
  }, 4000);
};
let heartCheck = {
  timeout: 6000, // 6秒
  timeoutObj: null,
  reset: function() {
    clearInterval(this.timeoutObj);
    return this;
  },
  start: function() {
    this.timeoutObj = setInterval(function() {
      // 这里发送一个心跳,后端收到后,返回一个心跳消息,
      // onmessage拿到返回的心跳就说明连接正常
      websocket.send('HeartBeat');
    }, this.timeout);
  },
};
// 关闭连接
let closeWebSocket = () => {
  websocket && websocket.close();
};
export { websocket, createWebSocket, closeWebSocket };
相关文章
|
4月前
|
设计模式 Java Spring
【Spring源码】WebSocket做推送动作的底层实例是谁
我们都知道WebSocket可以主动推送消息给用户,那做推送动作的底层实例究竟是谁?我们先整体看下整个模块的组织机构。可以看到handleMessage方法定义了每个消息格式采用不同的消息处理方法,而这些方法该类并**没有实现**,而是留给了子类去实现。
【Spring源码】WebSocket做推送动作的底层实例是谁
|
4月前
|
前端开发 JavaScript API
第八章 react组件实例中三大属性之ref
第八章 react组件实例中三大属性之ref
|
4月前
|
前端开发 数据库
第七章 react组件实例中三大属性之props
第七章 react组件实例中三大属性之props
|
27天前
|
前端开发
React组件实例更改state状态值(四)
【8月更文挑战第14天】React组件实例更改state状态值(四)
26 1
React组件实例更改state状态值(四)
|
27天前
|
前端开发 JavaScript
React组件实例state(三)
【8月更文挑战第14天】React组件实例state(三)
25 1
React组件实例state(三)
|
4月前
|
存储 前端开发 API
第六章 react组件实例中三大属性之State
第六章 react组件实例中三大属性之State
|
2月前
|
缓存 前端开发 JavaScript
React Hooks(实例及详解)
【7月更文挑战第2天】React Hooks(实例及详解)
42 3
|
4月前
|
存储 JavaScript 前端开发
React中的Redux:简介和实例代码
React中的Redux:简介和实例代码
59 1
|
4月前
|
XML 前端开发 JavaScript
【前端】深入了解React JSX语法及实例应用
【前端】深入了解React JSX语法及实例应用
48 0
|
前端开发 JavaScript Android开发
React Native 和 Flutter对比,包含代码实例
@[TOC](目录) React Native 和 Flutter 都是流行的跨平台移动应用开发框架。虽然它们在很多方面都有相似之处,但它们也有一些不同之处。在本文中,我们将详细比较这两个框架,讨论它们的优缺点、应用场景、性能以及包含的代码。 # 1. 框架概述 React Native 是由 Facebook 开发的一个开源框架,它允许开发者使用 JavaScript 和 React 来创建原生移动应用。React Native 可以用于开发 iOS、Android 和 Web 应用。它使用 JavaScript 的生态系统和工具,如 Babel、ESLint 和 React 工具链,使得开
159 0

热门文章

最新文章