使用 setState 强制组件重新渲染未按预期工作
Forcing component re-render with setState not working as expected
我正在使用 react-usa-map 包来可视化美国地图 (https://www.npmjs.com/package/react-usa-map)。我按照包的说明创建了我的地图组件,但在选择状态时我面临重新渲染它的问题。这是我的整个组件代码:
import React, { useState, useEffect } from "react";
import "./map.css";
import USAMap from "react-usa-map";
const PublicGraphMap = () => {
const [selected, setSelected] = useState();
const mapHandler = (event) => {
setSelected(event.target.dataset.name);
};
const statesFilling = (state) => {
console.log(state); // OUTPUTING THE CHOSEN STATE CORRECT
return {
state: {
fill: "navy",
clickHandler: () => console.log(state),
},
};
};
return <USAMap customize={statesFilling(selected)} onClick={mapHandler} />;
};
export default PublicGraphMap;
出于某种原因,一切正常,并且在 statesFilling() 中选择的函数在控制台中正确显示。但我不知道为什么 returning 不起作用。 return 对象中的所有内容都无法正常工作,如果我在这里放置 NJ 而不是 state:
return {
NJ: {
fill: "navy",
clickHandler: () => console.log(state),
},
};
};
给新泽西州上色没问题。
这是沙箱示例:
https://codesandbox.io/s/pedantic-kowalevski-7rt7d?file=/src/App.js
我希望能够动态地选择状态并为其着色。
您需要将键指定为州代码,而不是文字“州”。
const statesFilling = (state) => {
console.log(state);
return {
[state]: { // <-- interpolate the state value to be used as key
fill: "navy",
clickHandler: () => console.log(state)
}
};
};
我正在使用 react-usa-map 包来可视化美国地图 (https://www.npmjs.com/package/react-usa-map)。我按照包的说明创建了我的地图组件,但在选择状态时我面临重新渲染它的问题。这是我的整个组件代码:
import React, { useState, useEffect } from "react";
import "./map.css";
import USAMap from "react-usa-map";
const PublicGraphMap = () => {
const [selected, setSelected] = useState();
const mapHandler = (event) => {
setSelected(event.target.dataset.name);
};
const statesFilling = (state) => {
console.log(state); // OUTPUTING THE CHOSEN STATE CORRECT
return {
state: {
fill: "navy",
clickHandler: () => console.log(state),
},
};
};
return <USAMap customize={statesFilling(selected)} onClick={mapHandler} />;
};
export default PublicGraphMap;
出于某种原因,一切正常,并且在 statesFilling() 中选择的函数在控制台中正确显示。但我不知道为什么 returning 不起作用。 return 对象中的所有内容都无法正常工作,如果我在这里放置 NJ 而不是 state:
return {
NJ: {
fill: "navy",
clickHandler: () => console.log(state),
},
};
};
给新泽西州上色没问题。 这是沙箱示例:
https://codesandbox.io/s/pedantic-kowalevski-7rt7d?file=/src/App.js
我希望能够动态地选择状态并为其着色。
您需要将键指定为州代码,而不是文字“州”。
const statesFilling = (state) => {
console.log(state);
return {
[state]: { // <-- interpolate the state value to be used as key
fill: "navy",
clickHandler: () => console.log(state)
}
};
};