У меня есть основной компонент App.js, который отображает диаграмму рассеяния с D3, которая, в свою очередь, отображает диаграмму, также с D3
Когда щелкают точку на точке рассеяния, основываясь на значении точки,один из 2 столбцов создается (при первом щелчке) или обновляется новыми данными (при последующих щелчках).
С помощью приведенного ниже упрощенного кода вместо обновления данных на исходном графике создается новый столбчатый график.добавляется к элементу div с каждым кликом.Как изменить код componentDidUpdate () в разделе barplot.js, чтобы обновлять исходную диаграмму барплота?
//Data is input here
const scatterPlotData = [
[5, 20], [48, 90], [250, 50], [100, 33], [330, 95],
[410, 12], [475, 44], [25, 67], [85, 21], [220, 88]
];
const bardata1 = [ 5, 10, 13, 19, 21, 25, 22, 18, 15, 13,11, 12, 15, 20, 18, 17, 16, 18, 23, 25 ];
const bardata2 = [ 1, 20, 33, 5, 7, 25, 22, 10, 1, 23,31, 2, 5, 40, 28, 27, 6, 8, 3, 5 ];
class ScatterPlot extends Component {
createScatterPlot() {
//d3 code here, relevant part which determines which barplot data to select
.on("click", function(d) {
//If x value of scatterplot point is >= 200, choose bar plot data above
if (d[0] >= 200) {
component.setState({ bardata: bardata2, event: d3.event });
} else {
component.setState({ bardata: bardata1, event: d3.event });
}
})
}
render() {
return (
<div>
{
//BarPlot class is called
this.state.bardata && this.state.event &&
<BarPlot bardata={this.state.bardata}/>
}
</div>
)
}
}
class BarPlot extends Component {
constructor(props){
super(props)
this.createBarPlot = this.createBarPlot.bind(this)
}
componentDidMount() {
this.createBarPlot()
}
componentDidUpdate(prevProps) {
if(JSON.stringify(this.props.bardata) !== JSON.stringify(prevProps.bardata)) {
this.setState({bardata: null});
this.createBarPlot()
}
}
createBarPlot() {
//d3 code here
}
render() {
return (
<div>
</div>
)
}
}
//Main app which calls the ScatterPlot class
class App extends Component {
constructor(props) {
super(props)
this.state = {
pointdata: pointdata1
}
}
render() {
return (
<div className="wrapper">
<header className="App-header">
Scatter Plot via React
</header>
<div id = 'plot-1'>
<ScatterPlot pointdata={this.state.pointdata} />
</div>
<div id="barplot"></div>
</div>
);
}