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 相关文章推荐
FormValid0.5版本发布,带ajax自定义验证例子
Aug 17 Javascript
jquery 多级下拉菜单核心代码
May 21 Javascript
js取整数、取余数的方法
May 11 Javascript
浅谈jQuery animate easing的具体使用方法(推荐)
Jun 17 Javascript
javascript中的 object 和 function小结
Aug 14 Javascript
JS实现按钮添加背景音乐示例代码
Oct 17 Javascript
JS组件系列之Gojs组件 前端图形化插件之利器
Nov 29 Javascript
JQuery扩展对象方法操作示例
Aug 21 jQuery
小程序:授权、登录、session_key、unionId的详解
May 15 Javascript
vue学习笔记之slot插槽基本用法实例分析
Feb 01 Javascript
基于js实现判断浏览器类型代码实例
Jul 17 Javascript
ES6字符串的扩展实例
Dec 21 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
PHP源码分析之变量的存储过程分解
2014/07/03 PHP
thinkPHP中验证码的简单使用方法
2015/12/26 PHP
老生常谈PHP面向对象之解释器模式
2017/05/17 PHP
JS实现日期加减的方法
2013/11/29 Javascript
JavaScript数据类型之基本类型和引用类型的值
2015/04/01 Javascript
seajs加载jquery时提示$ is not a function该怎么解决
2015/10/23 Javascript
JavaScript几种数组去掉重复值的方法推荐
2016/04/12 Javascript
Bootstrap CSS组件之按钮下拉菜单
2016/12/17 Javascript
基于canvas粒子系统的构建详解
2017/08/31 Javascript
canvas绘制爱心的几种方法总结(推荐)
2017/10/31 Javascript
详解vue如何使用rules对表单字段进行校验
2018/10/17 Javascript
微信小程序使用setData修改数组中单个对象的方法分析
2018/12/30 Javascript
借助云开发实现小程序短信验证码的发送
2020/01/06 Javascript
Vue filter 过滤器、以及在table中的使用介绍
2020/09/07 Javascript
vue 如何从单页应用改造成多页应用
2020/10/23 Javascript
用Python代码来解图片迷宫的方法整理
2015/04/02 Python
在DigitalOcean的服务器上部署flaskblog应用
2015/12/19 Python
Python实现的密码强度检测器示例
2017/08/23 Python
python xlsxwriter库生成图表的应用示例
2018/03/16 Python
Python使用Pandas库实现MySQL数据库的读写
2019/07/06 Python
python求绝对值的三种方法小结
2019/12/04 Python
使用pygame编写Flappy bird小游戏
2020/03/14 Python
解决paramiko执行命令超时的问题
2020/04/16 Python
解决keras,val_categorical_accuracy:,0.0000e+00问题
2020/07/02 Python
python 实现一个图形界面的汇率计算器
2020/11/09 Python
css3+伪元素实现鼠标移入时下划线向两边展开的效果
2017/04/25 HTML / CSS
美特斯邦威官方商城:邦购网
2016/10/13 全球购物
高级Java程序员面试要点
2013/08/02 面试题
房产买卖委托公证书
2014/04/04 职场文书
公安交警中队队长个人对照检查材料思想汇报
2014/10/05 职场文书
职代会闭幕词
2015/01/28 职场文书
会计工作能力自我评价
2015/03/05 职场文书
煤矿百日安全活动总结
2015/05/07 职场文书
TV动画「神渣☆爱豆」公开第一弹主视觉图
2022/03/21 日漫
Java中Quartz高可用定时任务快速入门
2022/04/03 Java/Android
使用CSS实现六边形的图片效果
2022/08/05 HTML / CSS