Обновление данных для диаграммы D3 с использованием реакции - PullRequest
0 голосов
/ 02 декабря 2018

У меня есть основной компонент 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>

    );

  }
...