react实现同页面三级跳转路由布局


Posted in Javascript onSeptember 26, 2019

本文实例为大家分享了react实现同页面三级跳转路由布局的具体代码,供大家参考,具体内容如下

react实现同页面三级跳转路由布局

 一级路由+布局组件:

//嵌套路由小案例 布局页面一级路由
import React from 'react'
import {BrowserRouter as Router, Route, Link} from 'react-router-dom' //引入路由要用的组件
import Index from './Index' //二级路由 首页
import Video from './Video' // 二级路由 视频
import Workplace from './Workplace' //二级路由 职场
import './Router.css'
 
//假设是后端获取的动态路由
function AppRouter(){
  let routeConfig = [
    {path:'/',title:'博客首页',exact:true,component:Index},
    {path:'/video',title:'视频教程',exact:false,component:Video},
    {path:'/workplace',title:'职场技能',exact:false,component:Workplace},
  ]
  return(
    <Router>
      <div className='mainDiv'>
        {/* 左侧导航部分 */}
        <div className='leftNav'>
          <h3>一级导航</h3>
          <ul>
            {/* 渲染动态路由 */}
            {
              routeConfig.map((item,index)=>{
                return (
                  <li key={index}>
                    <Link to={item.path}>{item.title}</Link>
                  </li>
                )
              })
            }
          </ul>
        </div>
        {/* 右侧显示部分 */}
        <div className='rightMain'>
          {
           routeConfig.map((item,index)=>{
            return (
              <Route key={index} exact={item.exact} path={item.path} component={item.component} />
            )
          }) 
          }
        </div>
      </div>
    </Router>
  )
}
 
export default AppRouter

布局css:

body{
  padding: 0px;
  margin: 0px;
}
 
.mainDiv{
  display: flex;
  width: 100%;
}
.leftNav{
  width: 16%;
  background-color: #c0c0c0;
  color:#333;
  font-size:24px;
  height: 1000px;
  padding: 20px;
}
.rightMain{
  width: 84%;
  height:1000px;
  background-color: #fff;
  font-size:20px;
}

二级路由 首页组件

//首页 二级路由
 
import React,{Component} from 'react'
 
class Index extends Component {
  constructor(props) {
    super(props);
    this.state = { }
  }
  render() { 
    return ( 
    <div>
      <h2>我是首页</h2>
    </div> 
    );
  }
}
 
export default Index;

二级路由 视频组件

//视频页面 二级路由
 
import React from 'react'
import { Route, Link} from 'react-router-dom'
import ReactPage from './video/ReactPage'
import Flutter from './video/Flutter'
import Vue from './video/Vue'
import './Video.css'
 
function Video(){
  return(
    <div>
      <div className='topNav'>
        <ul>
          <li><Link to='/video/reactpage/'>React教程</Link></li>
          <li><Link to='/video/Flutter/'>Flutter教程</Link></li>
          <li><Link to='/video/Vue/'>Vue教程</Link></li>
        </ul>
      </div>
      <div className='videoContent'>
        <div>
          <h3>视频教程</h3>
          <Route path='/video/reactpage/' component={ReactPage} />
          <Route path='/video/Flutter/' component={Flutter} />
          <Route path='/video/Vue/' component={Vue} />
        </div>
      </div>
    </div>  
  )
}
 
export default Video

 三级路由 视频 子页面

//三级路由
import React from 'react'
 
function Flutter(){
  return (
    <h2>
      我是Flutter
    </h2>
  )
}
 
export default Flutter
//三级路由
import React from 'react'
 
function ReactPage(){
  return (
    <h2>
      我是react
    </h2>
  )
}
 
export default ReactPage
..

其余二级三级页面类似

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
top.location.href 没有权限 解决方法
Aug 05 Javascript
javascript 进阶篇3 Ajax 、JSON、 Prototype介绍
Mar 14 Javascript
extjs关于treePanel+chekBox全部选中以及清空选中问题探讨
Apr 02 Javascript
原始XMLHttpRequest方法详情回顾
Nov 28 Javascript
js写的评论分页(还不错)
Dec 23 Javascript
jQuery实现单击按钮遮罩弹出对话框(仿天猫的删除对话框)
Apr 10 Javascript
详细解读JavaScript的跨浏览器事件处理
Aug 12 Javascript
使用jQuery.form.js/springmvc框架实现文件上传功能
May 12 Javascript
全面理解JavaScript中的闭包
May 12 Javascript
jQuery控制input只能输入数字和两位小数的方法
May 16 jQuery
微信小程序利用Canvas绘制图片和竖排文字详解
Jun 25 Javascript
js实现树形数据转成扁平数据的方法示例
Feb 27 Javascript
vue轮播组件实现$children和$parent 附带好用的gif录制工具
Sep 26 #Javascript
小程序调用微信支付的方法
Sep 26 #Javascript
细说webpack6 Babel的使用详解
Sep 26 #Javascript
微信小程序实现拖拽功能
Sep 26 #Javascript
vue用BMap百度地图实现即时搜索功能
Sep 26 #Javascript
layui.tree组件的使用以及搜索节点功能的实现
Sep 26 #Javascript
微信小程序点击列表跳转到对应详情页过程解析
Sep 26 #Javascript
You might like
mac下使用brew配置环境的步骤分享
2011/05/23 PHP
PHP用户验证和标签推荐的简单使用
2016/10/31 PHP
php防止sql注入的方法详解
2017/02/20 PHP
PHP开发api接口安全验证操作实例详解
2020/03/26 PHP
Javascript的匿名函数小结
2009/12/31 Javascript
javascript中的new使用
2010/03/20 Javascript
锋利的jQuery 要点归纳(三) jQuery中的事件和动画(上:事件篇)
2010/03/24 Javascript
js正则表达式的使用详解
2013/07/09 Javascript
jQuery$命名冲突怎么办如何解决
2014/01/16 Javascript
ie7+背景透明文字不透明超级简单的实现方法
2014/01/17 Javascript
JavaScript实现横向滑出的多级菜单效果
2015/10/09 Javascript
使用JavaScript和CSS实现文本隔行换色的方法
2015/11/04 Javascript
JavaScript中iframe实现局部刷新的几种方法汇总
2016/01/06 Javascript
HTML5+jQuery插件Quicksand实现超酷的星际争霸2兵种分类展示效果(附demo源码下载)
2016/05/25 Javascript
javascript使用闭包模拟对象的私有属性和方法
2016/10/05 Javascript
js中常用的Math方法总结
2017/01/12 Javascript
vue-router 学习快速入门
2017/03/01 Javascript
原生js通过一行代码实现简易轮播图
2019/06/05 Javascript
Vue 自定义标签的src属性不能使用相对路径的解决
2019/09/17 Javascript
[55:32]2018DOTA2亚洲邀请赛 4.4 淘汰赛 EG vs LGD 第二场
2018/04/05 DOTA
python基于socket实现网络广播的方法
2015/04/29 Python
Python实现的简单算术游戏实例
2015/05/26 Python
Python 给定的经纬度标注在地图上的实现方法
2019/07/05 Python
html5的localstorage详解
2017/05/09 HTML / CSS
使用phonegap播放音频的实现方法
2017/03/31 HTML / CSS
毕业生个人的求职信范文
2013/12/03 职场文书
土木工程专业个人求职信
2013/12/05 职场文书
元旦晚会邀请函
2014/02/01 职场文书
纠纷协议书
2014/04/16 职场文书
工地宣传标语
2014/06/18 职场文书
乡镇遵守党的政治纪律情况对照检查材料
2014/09/26 职场文书
2015年技术员工作总结
2015/04/10 职场文书
读《教育心理学》心得体会
2016/01/22 职场文书
导游词之河北野三坡
2019/12/11 职场文书
MySQL分库分表与分区的入门指南
2021/04/22 MySQL
服务器SVN搭建图文安装过程
2022/06/21 Servers