React-Router完成后台管理系统登陆功能

此文仅通过后台管理系统登陆的demo来讲解React-Router的使用,通过React-Router来实现页面跳转功能

安装依赖

安装react-router-dom依赖包

npm install --save react-router-dom
页面使用

这里我们通过一个后台系统的路由功能来使用react-router-dom中的路由功能以及什么是BrowserRouter,RouteLink
后台系统路由功能需求:

  • 有一个登陆页,验证账号后,跳转进后台管理页面(实现页面平级跳转)
  • 进入后台管理页之后,根据顶部导航跳转下方的展示页面(实现子路由跳转概念)

首先,我们需要设置一层顶级路由,用来控制页面的平级跳转功能.实现通过登录页跳转到管理首页
那么我们需要给react项目的入口文件index.jsdom节点挂载的就不是一个组件了,而是一个路由js(由于该组件只实现页面路由的分发,并不需要继承component,所以使用function也是可以的,我们通常称之为无状态组件).

index.js

import React from 'react'

import ReactDOM from 'react-dom'
import App from './AppRouter'

ReactDOM.render(<App />, document.getElementById('root'))

js中挂在的App组件到页面节点root上,实际上我们是引入了一个AppRouter的js文件.用于分发路由功能

AppRouter.js

import React from 'react'
import { BrowserRouter as Router, Route, Link } from 'react-router-dom'
import LoginPage from './pages/Login/Login'
import Index from './pages/Index/index'
function AppRouter () {
  return (
    <Router>
      <ul>
        <li><Link to="/">登陆</Link></li>
        <li><Link to="/index/">首页</Link></li>
      </ul>
      <Route path="/" exact component={LoginPage} />
      <Route path="/index/" component={Index} />
    </Router>
  )
}
export default AppRouter

页面中,我们引入了react-router-dom中的3个组件,这里我们需要了解一下BrowserRouter,Route以及Link

  • BrowserRouter我们可以理解为路由器,为了使用方便起见,我们通过as重命名为Router
  • Route 我们可以理解是路由的线路,也就是我们的rul跳转后,需要显示内容的区块,通过path来拦截展示
  • Link 可以理解为页面的a标签,用于跳转使用,配合to传递rul进行点击跳转.

路由功能已经实现了,我们要实现登陆页面跳转至首页,这里为了方便演示,我们在Router组件中,加入了一个有序列表,进行跳转.实际的登陆页是没有这一块内容的,只需要把无序列表删除即可,Route组件已经实现了url的拦截功能,并渲染component属性指向的组件

/pages/Login.js

import React, { Component } from 'react';

class Login extends Component {
  constructor(props) {
    super(props);
    this.state = {}
  }
  render () {
    return (
      <div>这里是登录页</div>
    );
  }
}

export default Login;

/pages/Index.js

import React, { Component } from 'react';
import { BrowserRouter as Router, Route, Link } from 'react-router-dom'
class Index extends Component {
  constructor(props) {
    super(props);
    this.state = {}
  }
  render () {
    return (
      <div className="index_box">这里是登陆后的首页</div>
    );
  }
}

export default Index;
页面子路由

当从登陆页跳转到管理首页的时候,顶部导航栏作为路由跳转按钮,下方的部分则作为路由子页面存在
管理首页 pages/index.js

import React, { Component } from 'react';
import { BrowserRouter as Router, Route, Link } from 'react-router-dom'

import MailList from '../MailList/MailList.js'
import EngineeringProject from '../EngineeringProject/EngineeringProject'
import Business from '../Business/Business'
import SetupPage from '../SetupPage/SetupPage'
import './index.scss'
class Index extends Component {
  constructor(props) {
    super(props);
    this.state = {}
  }
  render () {
    return (
      <div className="index_index_box">
        <Router>
          <div className="index_top_box">
            <div className="index_topbox_box1">
              <div className="index_logobox">
                <div className="logo"></div>
                <div className="logoname">大汇云</div>
              </div>
              <div className="index_topbox_infobox">
                <div>信息</div>
                <div>语音</div>
                <div>退出</div>
              </div>
            </div>
            <div className="index_topbox_box2">
              <ul className="minbox">
                <li><Link to="/index/maillist/">企业通讯录</Link></li>
                <li><Link to="/index/engineeringproject/">工程项目</Link></li>
                <li><Link to="/index/business/">我的企业</Link></li>
                <li><Link to="/index/setuppage/">设置管理</Link></li>
              </ul>
            </div>
          </div>
          <div className="index_body">

            <Route path="/index/maillist/" component={MailList} />
            <Route path="/index/engineeringproject/" component={EngineeringProject} />
            <Route path="/index/business/" component={Business} />
            <Route path="/index/setuppage/" component={SetupPage} />

          </div>
          <div className="pageinfo">© 2018 - 2019 DHwork ltc. All Rights Reserved</div>
        </Router>
      </div>
    );
  }
}

export default Index;

此时的目录结构:


image.png

此时,我们在'/pages/Index'目录的下方建立一个scss文件,用于页面样式:

.index_index_box{
  width:100%;
  background:rgba(234,235,239,1);
  .index_top_box {
    width:100%;
    height:74px;
    background: white;
    .index_topbox_box1{
      display: flex;
      justify-content: space-between;
      width:100%;
      height:31px;
      border-bottom: 1px solid #F7F7F7;
      .index_logobox{
        height:31px;
        width:150px;
        display:flex;
        .logo{
          width:60px;
          height:31px;
          background: #346EFF;
        }
        .logoname{
          padding: 0 10px;
          line-height:32px;
          font-size: 12px;
          color:rgba(0,6,25,1);
        }
      }
      .index_topbox_infobox{
        padding-right: 42px;
        display:flex;
        justify-content: flex-end;
        width:300px;
        div{
          margin-left:43px;
          line-height:32px;
          font-size:12px;
          cursor: pointer;
        }
      }
    }
    .index_topbox_box2{
      width:100%;
      height:42px;
      .minbox{
        margin: 0 auto;
        width:686px;
        height:42px;
        display:flex;
        justify-content: space-between;
        li{
          list-style: none;
        }
        a{
          line-height:42px;
          font-size:14px;
          color:rgba(0,6,25,.6);
          cursor: pointer;
          text-decoration: none;
        }
      }
    }
  }
  .index_body{
    background: white;
    height: calc(100vh - 134px);
    margin: 20px auto;
    width:1200px;
  }
  .pageinfo{
    text-align: center;
    color:rgba(0,6,25,.3);
    font-size:12px;
  }
}

路由分别引入企业通讯录页面,工程项目页面,我的企业以及设置管理页面.
当点击顶部导航,下方的区域切换到对应的页面中,最终呈现样式,


image.png
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,544评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,430评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,764评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,193评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,216评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,182评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,063评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,917评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,329评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,543评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,722评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,425评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,019评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,671评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,825评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,729评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,614评论 2 353

推荐阅读更多精彩内容