【发布时间】:2021-07-09 11:54:15
【问题描述】:
我希望显示新状态,但我得到了不同的行为。我有三个点(查看下面的代码或草图),如果我单击一个点,那么无论当时的状态值是什么,将来单击都会显示旧值。我不确定这是由什么引起的。
例如: 单击点 A,然后打印 0。 递增状态,然后点击A,还是打印0。 单击点 B,打印 1。 点击A点,还是打印0。
草图:https://stackblitz.com/edit/react-bwskb9?file=index.js
import React, { useState, useEffect } from "react";
import { render } from "react-dom";
import HighchartsReact from "highcharts-react-official";
import Highcharts from "highcharts";
const LineChart = () => {
const [hoverData, setHoverData] = useState(null);
const [someState, setSomeState] = useState(0);
const [chartOptions, setChartOptions] = useState({
xAxis: {
categories: ["A", "B", "C"]
},
series: [{ data: [1, 2, 3] }],
plotOptions: {
series: {
point: {
events: {
click(e) {
console.log(someState);
setHoverData(e.point.category);
}
}
}
}
}
});
const updateSeries = () => {
setChartOptions({
plotOptions: {
series: {
point: {
events: {
click(e) {
console.log(someState);
setHoverData(e.point.category);
}
}
}
}
}
});
};
useEffect(() => {
updateSeries();
}, [someState]);
return (
<div>
<HighchartsReact highcharts={Highcharts} options={chartOptions} />
<h3>Clicked over {hoverData}</h3>
<button onClick={() => setSomeState(val => val + 1)}>Incr</button>
<p>{someState}</p>
</div>
);
};
render(<LineChart />, document.getElementById("root"));
【问题讨论】:
-
我可能错过了,但
someState和hoverData之间是否存在双向连接? -
@DarshnaRekha 不,这只是举例。
someState只是一个计数器变量。hoverData显示您最后单击的点。我需要以某种方式创建连接吗?我不确定你的意思。
标签: javascript reactjs highcharts