Как обновить компонент карты при нажатии на изображение? - PullRequest
0 голосов
/ 24 февраля 2019

Я учусь использовать React JS и Ant Design, но в настоящее время нахожусь в тупике.

Я хочу создать простую страницу реакции без сохранения состояния, где отображаются изображения персонажей из Диснея.При нажатии на изображения компонент карты обновляется информацией о персонаже (например, пол, рост, виды и т. Д.).Если я нажму на изображение другого персонажа, его информация будет обновлена ​​до того же компонента Карты.Я не могу найти хороший источник с инструкциями о том, как обновить компонент карты.

Если есть лучший метод для выполнения той же задачи, когда щелчок по изображению может обновить простое поле, содержащее информацию о персонаже, тогда я был бы рад изучить альтернативный метод.

Любойпонимание, которое каждый может предоставить, будет с благодарностью.Спасибо.

1 Ответ

0 голосов
/ 25 февраля 2019

Самое простое решение - создать простой массив объектов, содержащий информацию, которую вы хотите визуализировать.Получив это, мы можем просто сопоставить это с новым массивом компонентов Princess Card, который просто содержит логику, чтобы показать / скрыть дополнительную информацию.

Полный пример работы см. В примере codesandbox.

princesses: [
      {
        name: "Rapunzel",
        image:
          "https://lumiere-a.akamaihd.net/v1/images/character_princess_rapunzel_314b7a09.jpeg?region=0%2C0%2C450%2C450&optimize=true",
        height: "5' 1",
        weight: 95,
        age: "18"
      },
      {
        name: "Anna",
        image:
          "",
        height: "5' 0",
        weight: 92,
        age: "18"
      },
      {
        name: "Merida",
        image:
          "https://lumiere-a.akamaihd.net/v1/images/character_princess_merida_eb06acab.jpeg?region=0,0,450,450",
        height: "5' 4",
        weight: 104,
        age: "16"
      }
]
class PrincessCard extends React.Component {
  state = {
    open: false
  };
  toggleOpen = () => this.setState(prevState => ({ open: !prevState.open }));
  render() {
    return (
      <Col xs={8}>
        <Card
          hoverable={true}
          cover={<img alt={this.props.name} src={this.props.data.image} />}
          actions={[
            <Button block={true} onClick={this.toggleOpen}>
              {this.state.open ? "Show less info" : "Show more info"}
            </Button>
          ]}
        >
          {this.props.data.name}
          {this.state.open && (
            <React.Fragment>
              <Divider />
              <List
                bordered
                dataSource={[
                  `Age: ${this.props.data.age}`,
                  `Height: ${this.props.data.height}`,
                  `Weight: ${this.props.data.weight}`
                ]}
                renderItem={item => <List.Item>{item}</List.Item>}
              />
            </React.Fragment>
          )}
        </Card>
      </Col>
    );
  }
}

https://codesandbox.io/s/5kpmrrwxo4

...