有两种页面,一种是有TabBar的页面,如下图; 一种是无TabBar的页面
有TabBar的页面使用嵌套路由来实现
嵌套路由:路由内部包含路由
使用步骤
1 在pages文件夹创建News/index.js组件(子路由要展示的内容)
import React from "react"
export default class News extends React.Component{
render(){
return <div style={{background:'yellow',padding:10}}>
这是news组件的内容,是子路由的内容</div>
}
}
2 在Home组件中,添加一个Route作为子路由(嵌套路由)的出口
3 设置嵌套路由的path,格式以父路由path开头(父组件展示、子组件才会展示)
Home/index.js
import React from "react"
//导入路由
import {Route} from "react-router-dom"
//导入News组件
import News from "../News/index"
export default class Home extends React.Component {
render() {
return <div style={{background:'skyblue',padding:10}}>
首页页面
{/*渲染子路由*/}
<Route path="/home/news" component={News}></Route>
</div>
}
}
父路由的path是"/home"
子路由的path是"/home/news"
效果
地址栏路径的pathname为父路由
修改地址栏路径的pathname为子路由
备注:蓝色部分就是父路由Home,黄色部分就是子路由news (父路由嵌套着子路由)