我对 React.js 很陌生,但我正在使用它构建一个单页应用程序。对于路由,我使用的是 react-router。
我想要组织我的页面的方式如下:我想要一个静态页眉和页脚(仅加载一次),然后页面的内容将根据路线而改变。这里没什么特别的,这基本上是我对SPA的理解。
这是使用路由引导我的应用程序的 main.js:
const store = configureStore();
ReactDOM.render(
<Provider store={store}>
<Router history={history}>
<Route path="/" component={App}>
<IndexRoute component={Home}/>
<Route path="shop-filters-left-3cols" component={ShopFiltersLeft3Cols}/>
<Route path="about" component={About}/>
<Route path="login" component={Login}/>
</Route>
</Router>
</Provider>,
document.getElementById('main')
);
这是组件App,它基本上包含了单页的结构:
export class App extends React.Component {
constructor(){
super();
this.render = this.render.bind(this);
}
render() {
console.log('Rendering App');
return (<div>
<LoginModal />
<Header/>
<div className="page-content">
{this.props.children}
</div>
<Footer/>
</div>);
}
}
因此,当我访问应用程序时,会加载组件“App”,然后将组件“Home”注入到主要内容中,因为它被声明为 IndexRoute。
直到这里一切都很好,问题是每次我从一个路由切换到另一个路由时,组件“应用程序”都会被渲染(我知道是因为我在控制台中看到了“渲染应用程序”日志)。这是我不明白的,据我了解,路由之间的切换不应该触发“App”组件的渲染,而只能触发动态注入的组件。
我不希望每次切换路由时都呈现页眉和页脚,恕我直言,这是拥有单页应用程序的好处。也许我不太了解 react-router 的工作原理,有人可以帮我吗?或者,如果我做错了什么,请告诉我什么是实现我需要的正确方法。
如果您需要查看任何其他代码,请不要犹豫。谢谢