首页 > 解决方案 > React路由器dom将数据从父组件传递到子路由器组件不传递props.match

问题描述

父组件 App.js 的内容:-

import React, { useEffect, useState } from "react";
import NavBar from "./components/NavBar";
import Signup from "./pages/Signup";
import Home from "./pages/Home";
import Book from "./pages/Book";

function App() {
  const [user, setUser] = useState();
  useEffect(() => {
    const token = "Bearer " + sessionStorage.getItem("token");
    if (token) {
      axios
        .get(process.env.REACT_APP_API_URL + "user/self", {
          headers: {
            Authorization: token,
            "Content-Type": "application/json",
          },
        })
        .then((res) => setUser(res.data));
    }
  }, []);

  return (
    <div className="container-fluid">
      <NavBar user={user} />
      <Route exact path="/" component={Home} />
      <Route path="/signup" component={Signup} />
      <Route exact path="/book/:id" component={() => <Book user={user} />} />
    </div>
  );
}

export default App;

对于路线: -

<Route exact path="/book/:id" component={() => <Book user={user} />} />

当我将组件值从 component={Book} 设置为 component={() => 我得到一个错误:-

TypeError:无法读取未定义的属性“参数”

那是因为我在 Book 组件中使用了“props.match.params.id”。

如何将带有 props.match 的用户状态传递给他的 Book 组件?

标签: reactjsreact-router-dom

解决方案


这就是你使用组件道具的方式

<Route exact path="/book/:id" component={Book} />

考虑使用renderprop 而不是component这样的 prop:

<Route exact path="/book/:id" render={(routeProps) => <Book user={user} {...routeProps} />} />


推荐阅读