ReactJS页眉和页脚

时间:2016-11-07 05:24:24

标签: javascript reactjs header footer materialize

我正在尝试创建布局组件,该组件将呈现标头页脚。这样我以后就可以像

一样使用布局
<Layout> ... </Layout>

显然,我在页眉和页脚中使用了路由。为此,我需要使用

<Router history...
 <Route path...

当我在layout.js中逐个执行此操作时(对于页眉和页脚:虽然我觉得这是错误的)。有用。页眉和页脚显示在浏览器中。 但是,他们无法正常工作 。在刷新时,页脚消失,​​有时两者都消失,页眉和页脚。我坚信,一个接一个地渲染路由器是造成这种故障的原因,但我无法找出正确的方法。此外,我不想使用以下代码段

header.js

import React from 'react';
import {Link} from 'react-router'
import {Navbar, NavItem} from 'react-materialize';

export default React.createClass({
  render(){
    return (
    <div>
      <Navbar brand='logo' right>
        <NavItem><Link to="/Home" activeClassName="active">Home</Link></NavItem>
        <NavItem><Link to="/Sign-In" activeClassName="active">Sign In</Link></NavItem>
        <NavItem><Link to="/Register" activeClassName="active">Register</Link></NavItem>
      </Navbar>
      {this.props.children}
    </div>
    )
  }
})

footer.js

import React, {Component} from 'react';
import {Link} from 'react-router'
import {Footer} from 'react-materialize';
import '../../resource/template.css'


class RT_Footer extends Component{
  render(){
    return (
    <div>
      {this.props.children}
      <Footer copyrights="&copy; 2015 Copyright Text"
          moreLinks={
            <Link className="grey-text text-lighten-4 right" href="#!">More Links</Link>
          }
          links={
            <ul>
              <li><Link to="/About Us" className="grey-text text-lighten-3">About Us</Link></li>
              <li><Link to="/Terms & Conditions" className="grey-text text-lighten-3">Terms & Conditions</Link></li>
              <li><Link to="/Help" className="grey-text text-lighten-3">Help</Link></li>
              <li><Link to="/Contact Us" className="grey-text text-lighten-3">Contact Us</Link></li>
            </ul>
          }
          className='example'
      >
        <h5 className="white-text">Footer Content</h5>
        <p className="grey-text text-lighten-4">You can use rows and columns here to organize your footer content.</p>
      </Footer>
    </div>
    );
  }
}
export default RT_Footer;

layout.js

import {Router, Route, browserHistory} from 'react-router'

class Layout extends Component {
  render(){
    return (
      <div>
      <span>
        <Router history={browserHistory}>
          <Route path="/" component={Header}>
           <Route path="/Home" component={Home}/>
           <Route path="/Sign-In" component={SignIn}/>
           <Route path="/Register" component={Register}/>
          </Route>
        </Router>
      </span>
      <span>
        <Router history={browserHistory}>
          <Route path="/" component={RT_Footer}>
           <Route path="/About Us" component={About}/>
           <Route path="/Terms & Conditions" component={TC}/>
           <Route path="/Register" component={Register}/>
          </Route>
        </Router>
      </span>
      </div>
    );
  }
}
export default Layout;

然后我只在index.js

中渲染布局

1 个答案:

答案 0 :(得分:16)

我建议你不要渲染路由器组件两次(我还没有检查过,但你可能不会)。< / p>

那么,路由器组件的工作原理如何:

  • 你给路由器一个历史记录(通过历史道具),在这里你可以使用同一个库中的browserHistory,这很好。
  • 然后使用带有路径的Route组件定义应用程序的所有现有路由,并在浏览器URL与此路径属性匹配时加载要加载的组件。

现在,在你的情况下,我建议你做那样的事情:

<强> app.js

import {Router, Route, browserHistory} from 'react-router'
import Layout from './components/Layout'
// Import here all the required components used by the router such as SignIn, Register, ...

render(
    <Layout>
        <Router history={browserHistory}>
            <Route path="/" component={RT_Footer}>
            <Route path="/About Us" component={About}/>
            <Route path="/Terms & Conditions" component={TC}/>
            <Route path="/Register" component={Register}/>
           // Add as many Route components as needed
        </Router>
    </Layout>,
    document.getElementById('react-anchor')

然后您的布局文件应如下所示:

<强> layout.js

import Header from './Header'
import Footer from './Footer'
import React, {Component} from 'react'

class Layout extends Component {
    render() {
        return (
            <div>
                <Header />
                {this.props.children}
                <Footer />
            </div>
        )
    }
}

在你的页眉和页脚组件中,渲染你想要的任何内容,提供链接以加载你可以使用的反应路由器或库提供的其他方式所请求的组件(参见他们的文档)

修改:

关注路径路径,例如&#34;条款&amp;条件&#34;可能不是一个有效的路径