1

我无法解决这个问题,我无法呈现component我调用nested path的HTML/page/detail

我的路由树

render(
    (<Router history={history}>
        <Route path="/" component={App}>
            <IndexRoute component={Index}/>
            <Route path="page" component={Page}>
                <Route path="/page/detail" component={Detail} />
            </Route>
        </Route>
    </Router>),
    document.getElementById('main')
)

我的 {App} 组件呈现这个:

render() {
    return (
        <div>
            <nav className="navbar">
                <ul className="nav navbar-nav navbar-right">
                    <li><Link className="menu-link" ref="menu" to="/page">Page Test</Link></li>
                </ul>
            </nav>
            <div id="content-wrapper">{this.props.children}</div>
        </div>
    )
}

我的路由/page/detail是从Link组件内部调用的,{Page}但如果我访问此链接,我只会看到 {Page} 组件呈现的内容。我已经搜索了一些关于使用 react-routers 的嵌套路由的解决方案,但我没有找到答案。

更新:

通过这个解决方案,我已经渲染了我的 {Detail} 组件的 html:我已经在 {Page} 组件中插入了它

{this.props.children || <div>My Detail page</div> }

更新 2

在我的 {Page} 组件中,我插入了一个 jQuery插件

mix() {
    $("#filter-gallery").mixItUp();
}

destroy() {
    $('#filter-gallery').mixItUp('destroy');
}

componentDidMount() {
    this.mix();
}

componentWillUnmount() {
    this.destroy();
}

此插件仅适用于 {Page} 刷新页面,如果我导航到 /page/detail 然后返回 /page 插件不起作用。

4

1 回答 1

2

我通过以这种方式设置路线找到了解决方案:

<Route path="studio" component={Studio} />
    <Route path="studio/detail" component={Calendar} />
于 2015-11-13T10:26:52.667 回答