javascript - 使用 reactjs 没有响应 socket.io
问题描述
两个信息:[HMR] 等待来自 WDS 的更新信号...
下载 React DevTools 以获得更好的开发体验:fb.me/react-devtools
错误: http: //127.0.0.1 :4001/socket.io/?EIO=3&transport=polling&t=N4qdmGu
加载资源失败:net::ERR_CONNECTION_REFUSED 应该怎么做才能使这项工作?
const express = require("express");
const http = require("http");
const socketIo = require("socket.io");
const axios = require("axios");
const port = process.env.PORT || 4001;
const index = require("./routes/index");
const app = express();
app.use(index);
const server = http.createServer(app);
const io = socketIo(server);
let interval;
io.on("connection", socket => {
console.log("New client connected");
if (interval) {
clearInterval(interval);
}
interval = setInterval(() => getApiAndEmit(socket), 10000);
socket.on("disconnect", () => {
console.log("Client disconnected");
});
});
const getApiAndEmit = async socket => {
try {
const res = await axios.get(
"https://api.darksky.net/forecast/db057094f57ede5e1f8d33d5e528e4b3/30.9871097,34.9408864"
);
let temp = (((res.data.currently.temperature - 32) * 5) / 9).toFixed(2);
socket.emit("FromAPI", temp);
} catch (error) {
console.error(`Error: ${error.code}`);
}
};
server.listen(port, () => console.log(`Wee wee i'm on port ${port}`));
比
import React, { Component } from "react";
import socketIOClient from "socket.io-client";
class App extends Component {
constructor() {
super();
this.state = {
response: false,
endpoint: "http://127.0.0.1:4001"
};
}
componentDidMount() {
const socket = socketIOClient(this.state.endpoint);
socket.on("FromAPI", data => this.setState({ response: data }));
}
render() {
const { response } = this.state;
return (
<div style={{ textAlign: "center" }}>
{
response ?
(<p>The temperature is {response} degrees</p>)
:
(<p>load load...</p>)
}
</div>
);
}
}
export default App;
解决方案
您必须首先连接到客户端的套接字服务器,以便添加这个
socket.on('connect', function(){});
在您的事件侦听器之前。
socket.on("FromAPI", data => this.setState({ response: data }));
推荐阅读
- angular - 每当单击片段时都会重新加载角度组件
- elasticsearch - 使用脚本化度量聚合获取 Web 会话详细信息
- sql - 如何获得每一个可能的不同组合?
- php - Prestashop 模块 Prestablog 返回未捕获的错误
- jackson - 使用 Jackson 解析 YAML 文件时出现 UnrecognizedPropertyException
- node.js - MongoError:无法将 $addToSet 应用于非数组字段。名为“trackTime”的字段具有非数组类型字符串
- excel - Excel公式将单元格中的所有数字与文本相加
- c# - xUnit,在测试中使用 DateTime UtcNow 失败,毫秒数
- javascript - Highcharts 非活动状态必须应用于除悬停项目之外的所有项目
- python - 根据同一熊猫数据框的另一列中是否存在子字符串为列分配值