React.js Как передать данные из родительского компонента в дочерний компонент

Я пытаюсь сделать запрос API по поиску и по идентификатору и хочу передать этот идентификатор другому компоненту, который будет отображать данные идентификатора на другой странице при нажатии кнопки, но я не могу передать эти данные другому компоненту, пожалуйста, может кто-нибудь помочь мне с этим, я пытаюсь изучить React и много исследовал, но не мог найти решение. Передача данных от родителя к ребенку и наоборот сбивает меня с толку. любая помощь будет по достоинству оценена.

Родительский компонент

import React from "react";
import axios from "axios";
import { Link } from "react-router-dom";
import ProductDetailPage from "./productdetailpage";

class ProductLists extends React.Component {
  state = {
    movies: [],
    name: "",
    para: "No Data"
  };

  onchange = event => {
    this.setState({ name: event.target.value });
  };

  onsubmit = event => {
    event.preventDefault();
    const nameValue = this.state.name;
    axios
      .get(`http://www.omdbapi.com/?apikey=bcfe7e46&s=${nameValue}`)
      .then(res => {
        const movies = res.data.Search;
        this.setState({ movies });
      });
  };

  viewDetail = id => {
    axios.get(`http://www.omdbapi.com/?apikey=bcfe7e46&i=${id}`).then(res => {
      const movieId = res.data;

      //below i'm trying to pass the movieId into other component
      const moviedata = <ProductDetailPage passMovieId={movieId} />;
      console.log(moviedata.props);
    });
  };

  render() {
    return (
      <div>
        <form onSubmit={this.onsubmit}>
          <input
            type="text"
            placeholder="Search Movie"
            onChange={this.onchange}
          />
        </form>
        {this.state.name === "" ? (
          <h1>No Data</h1>
        ) : (
          <ul>
            {this.state.movies.map(movie => (
              <li key={movie.imdbID}>
                <img alt="img" src={movie.Poster} />
                <h1>{movie.Title}</h1>
                <p>{movie.Year}</p>
                <button onClick={() => this.viewDetail(movie.imdbID)}>
                  <Link to="./productdetail">View More</Link>
                </button>
              </li>
            ))}
          </ul>
        )}
      </div>
    );
  }
}
export default ProductLists;

Дочерний компонент

import React from "react";

class ProductDetailPage extends React.Component {
  render() {
    return (
      <ul>
        <li>
          <img alt="img" src={this.props.movieId.Poster} />
          <h1>{this.props.movieId.Title}</h1>
          <p>{this.props.movieId.Plot}</p>
        </li>
      </ul>
    );
  }
}

export default ProductDetailPage;

1 ответ

Вы можете передать идентификатор в ссылке и переместить туда функцию ViewDetail:

    <Link movieId={movie.imdbID} to="./productdetail">View More</Link>

тогда это должно быть доступно как опора в этом компоненте:

https://reacttraining.com/react-router/web/api/Link/others

Другие вопросы по тегам