首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何将代码从路由传输到组件

如何将代码从路由传输到组件
EN

Stack Overflow用户
提问于 2019-10-19 11:25:37
回答 1查看 31关注 0票数 0

我有路线

代码语言:javascript
复制
            <BrowserRouter>
                <Navbar />
                <div className="container pt-4">
                    <Switch>
                        <Route path="/" exact component={Home}></Route>
                        <Route path="/files" component={Files}></Route>
                        <Route path="/signin" component={SignIn}></Route>
                        <Route path="/signup" component={SignUp}></Route>
                        <Route path="/:url_code" component={File}></Route>
                    </Switch>
                </div>
            </BrowserRouter>

如何传递:url_code一个File页面。

代码语言:javascript
复制
import React, { Fragment } from 'react';

import { Item } from './../components/Item.component';

export const File = () => {
    return (
        <Fragment>
            <h3>test</h3>
            <hr />
            <Item />
        </Fragment>
    );
};
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-10-19 15:23:03

您将需要给您的组件访问反应路由器的match对象。您可以使用名为withRouter的高阶组件来完成此操作。这使您可以作为传递给组件的道具访问locationhistorymatch。在那里,您可以通过url_code提取match.params片段。

代码语言:javascript
复制
import React, { Fragment } from 'react';
import { withRouter } from "react-router";

import { Item } from './../components/Item.component';
const File = ({ match }) => {
    return (
        <Fragment>
            <h3>{match.params.url_code}</h3>
            <hr />
            <Item />
        </Fragment>
    );
};

export withRouter(File)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58463188

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档