Как показать данные из массива реагировать? - PullRequest
0 голосов
/ 04 октября 2018

Мне нужно получить все значения для одного города из многомерного массива, а не для всех городов :) Я действительно не могу понять, как написать это правильно.Помогите мне, пожалуйста: (
Я только знаю, что это должно выглядеть так:

weatherData.filter((wData) => wData.name === this.props.name)  

Но я все еще не знаю, как заставить это работать.

 import React, { Component } from "react";
 import "bootswatch/journal/bootstrap.css";
 import "./App.css";
 import { NavItem, Nav, Grid, Row, Col } from "react-bootstrap";

 var reportsData = [
 {
  "id": "a101",
  "name": "Report #a101",
  "values": [
      {
          "count": 121,
          "name": "a1",
      }, {
          "count": 312,
          "name": "a2",
      },
      {
        "count": 639,
        "name": "a3"
    }, {
        "count": 19,
        "name": "a4"
    }
  ]
    },
    {
  "id": "b101",
  "name": "Report #b101",
  "values": [{
        "count": 163,
        "name": "b1"
    }, {
        "count": 938,
        "name": "b2"
    }, {
        "count": 233,
        "name": "b3"
    }, {
        "count": 475,
        "name": "b4"
    }
  ]
 }];

 class WeatherDisplay extends Component {
 constructor() {
 super();
 this.state = {
 activePlace: 0,
};
    }
 render() {
const activePlace = this.state.activePlace;
return (
  <div>
    <h1>Displaying Data for {this.props.id}</h1>

  <div>
    {reportsData.map(function(ub) {

    return (
      <div>
            <p>{ub.id}</p>
            <p>{ub.name}</p>
            {/* <p>{ub.values}</p> */}
      </div>
    )
  })}       
  </div>

  </div>
);
 }
}

 class App extends Component {
 constructor() {
 super();
 this.state = {
 activePlace: 0,
};
}
 render() {
const activePlace = this.state.activePlace;
return (
  <div>
    <Grid>
      <Row>
        <Col md={4} sm={4}>
          <h3>Menu</h3>
          <Nav
            bsStyle="pills"
            stacked
            activeKey={activePlace}
            onSelect={index => {
              this.setState({ activePlace: index });
            }}
          >
            {reportsData.map((place, index) => (
              <NavItem key={index} eventKey={index}>
              <br/>{place.id}
              </NavItem>
            ))}


          </Nav>
        </Col>
        <Col md={8} sm={8}>
          <WeatherDisplay key={activePlace} id={reportsData[activePlace].id}  />

        </Col>
      </Row>
    </Grid>
  </div>
);
}
}

 export default App;

1 Ответ

0 голосов
/ 04 октября 2018

Измените свой компонент следующим образом.

class WeatherDisplay extends Component {
  
  constructor(props) {
    super(props);
    this.state = {
      activePlace: 0
    };
  }

  render() {
    const { activePlace } = this.state;
    const { id } = this.props;
    
    return (
      <div>
        <h1>Displaying Data for {id}</h1>
        <div>
          {reportsData.filter((i) => i === id).map((ub) => (
            <div>
              <p>{ub.id}</p>
              <p>{ub.name}</p>
              {ub.values.map((i) => (
                <p>
                  {i.name}: {i.count}
                </p>
              ))}
            </div>
          ))}
        </div>
      </div>
    );
  }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...