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 相关文章推荐
jQuery动态添加的元素绑定事件处理函数代码
Aug 02 Javascript
深入理解JavaScript系列(47):对象创建模式(上篇)
Mar 04 Javascript
js窗口震动小程序分享
Nov 28 Javascript
Angular.Js中ng-include指令的使用与实现
May 07 Javascript
基于angular实现模拟微信小程序swiper组件
Jun 11 Javascript
react native实现往服务器上传网络图片的实例
Aug 07 Javascript
vue 弹框产生的滚动穿透问题的解决
Sep 21 Javascript
vsCode安装使用教程和插件安装方法
Aug 24 Javascript
详解一个小实例理解js原型和继承
Apr 24 Javascript
Quasar Input:type=&quot;number&quot; 去掉上下小箭头 实现加减按钮样式功能
Apr 09 Javascript
JS的时间格式化和时间戳转换函数示例详解
Jul 27 Javascript
详解如何使用Node.js实现热重载页面
May 06 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
《斗罗大陆》六翼天使武魂最强,为什么老千家不是上三宗?
2020/03/02 国漫
PHP 翻页 实例代码
2009/08/07 PHP
ThinkPHP实现动态包含文件的方法
2014/11/29 PHP
php简单实现短网址(短链)还原的方法(测试可用)
2016/05/09 PHP
PHP7匿名类用法分析
2016/09/26 PHP
js创建对象的几种常用方式小结(推荐)
2010/10/24 Javascript
Extjs中使用extend(js继承) 的代码
2012/03/15 Javascript
javascript模拟实现C# String.format函数功能代码
2013/11/25 Javascript
javascript排序函数实现数字排序
2015/06/26 Javascript
JS建造者模式基本用法实例分析
2015/06/30 Javascript
jQuery-1.9.1源码分析系列(十一)DOM操作续之克隆节点
2015/12/01 Javascript
node.js实现爬虫教程
2020/08/25 Javascript
window.onload绑定多个事件的两种解决方案
2016/05/15 Javascript
Angular2从搭建环境到开发步骤详解
2016/10/17 Javascript
微信小程序 wx:key详细介绍
2016/10/28 Javascript
原生JS实现圣旨卷轴展开效果
2017/03/06 Javascript
Angular获取手机验证码实现移动端登录注册功能
2017/05/17 Javascript
解决VUE中document.body.scrollTop为0的问题
2018/09/15 Javascript
深入理解JavaScript的值传递和引用传递
2018/10/24 Javascript
浅谈Javascript常用正则表达式应用
2019/03/08 Javascript
angular6开发steps步骤条组件
2019/07/04 Javascript
Vue 使用计时器实现跑马灯效果的实例代码
2019/07/11 Javascript
vue实现员工信息录入功能
2020/06/11 Javascript
Vue 实现监听窗口关闭事件,并在窗口关闭前发送请求
2020/09/01 Javascript
小程序角标的添加及绑定购物车数量进行实时更新的实现代码
2020/12/07 Javascript
[02:30]辉夜杯主赛事第二日胜者组半决赛 CDEC.Y赛后采访
2015/12/26 DOTA
Python爬取读者并制作成PDF
2015/03/10 Python
浅析Python中的join()方法的使用
2015/05/19 Python
一张图带我们入门Python基础教程
2017/02/05 Python
Python二叉树定义与遍历方法实例分析
2018/05/25 Python
Python3如何在Windows和Linux上打包
2020/02/25 Python
pytorch VGG11识别cifar10数据集(训练+预测单张输入图片操作)
2020/06/24 Python
python爬虫构建代理ip池抓取数据库的示例代码
2020/09/22 Python
关于Python3的import问题(pycharm可以运行命令行import错误)
2020/11/18 Python
先进事迹材料范文
2014/12/29 职场文书
详解php中流行的rpc框架
2021/05/29 PHP