ReactJS_16 React路由设置:React Router

根据上一篇文章,我们基于webpack已经配置好react开发环境,接下来了解一下React Router 路由。
React Router路由在开发中时刻都会用到,它是SPA(单页应用)的基础,可以说不会路由系统基本就无法用React进行编程。其实路由可以简单的看作我们平时访问的网址或者路径,这样看有助于你的理解,但是并不正确。

Router包安装:

安装包还是要打开命令行工具,使用npm来进行安装。

npm install --save react-router react-router-dom

react-router:是基本的router包,里边函的内容较多,但是在网页开发中有很多用不到,现在的市面上的课程讲的基本都是这个包的教程。

react-router-dom:随着react生态环境的壮大,后出现的包,这个包比react-router包轻巧了很多。

注意:其实安装了react-router包就不用安装了react-router-dom包了,这里我们只是为了给大家一个提示,所以安装了两个包。在实际开发中,请根据需要进行安装。安装时使用--save,因为这是要在生产环境中使用的。

我们在/app文件夹下新建一个jsdemo.js页面。然后引进React包,并编写一个A页面的组件。请看下面的代码。

import React from 'react';
export default class jsdemo extends React.Component{
    render(){
        return(
            <div>A默认页面</div>
        );
    }
}

这里我们采用了ES6的类语法,这也是现在React推荐使用的,如果使用老语法会有一条黄色的警告或报错。

写好组件后,引入index.js页面,在头部加入引入语句,并改写渲染代码。

import React from 'react';
import ReactDOM from 'react-dom';
import Jsdemo from './jsdemo';
ReactDOM.render(
    <Jsdemo/>,
    document.getElementById("app")
);

引入完成后,执行npm run dev预览可以看到我们写的A页面的组件。通过上边基本的练习,我们有了一定经验,那么接下来我们仿照上面的方法制作两个新组件,jsdemob和jsdemoc。代码如下:

//jsdemob.js
import React from 'react';
export default class jsdemob extends React.Component{
    render(){
        return(
            <div>B页面</div>
        );
    }
}
//jsdemoc.js
import React from 'react';
export default class jsdemoc extends React.Component{
    render(){
        return(
            <div>B页面</div>
        );
    }
}

写完三个页面组件以后,我们把这三个页面都引入到index.js文件里边。

import Jsdemo from './jsdemo';
import Jsdemob from './jsdemob';
import Jsdemoc from './jsdemoc';

引入和书写路由

三个页面都已经作好,现在就需要路由来切换他们了,先用import引入我们的路由包,这里我们用两个模块,一个是Router(我自己叫它路由器),另一个是Route(我自己叫它路由)。

importi {BrowserRouter as Router , Route} from 'react-router-dom';

然后我们改写文件,增加路由设置。

ReactDOM.render(
    <Router>
        <div>
            <Route exact path="/" component={Jsdemo} />
            <Route  path="/Jsdemob" component={Jsdemob} />
            <Route  path="/Jsdemoc" component={Jsdemoc} />
        </div>
    </Router>,
    document.getElementById("app")
);

注意:这里的exact是精确匹配的意思,比如我们有多层路由进行嵌套时,exact可以帮助我们精确匹配到你想跳转的路由。exact的值为bool型,为true是表示严格匹配,为false时为正常匹配。

我们路由已经设置完毕了,但是我们现在还不能进行切换,那我们就做个切换的组件,命名为:Nav

制作Nav组件

/app文件夹下新建一个nav.js的文件,先引入reactreact-router-dom两个包。

import React from 'React';
import {NavLink} from 'react-router-dom';

编写基本的nav组件:

//nav.js
const NavBar = () =>(
<div>
    <div>
        <NavLink exact to='/'>Jsdemoa</NavLink> |&nbsp;
        <NavLink to='/Jsdemob'>Jsdemob</NavLink> |&nbsp;
        <NavLink to='/Jsdemoc'>Jsdemoc</NavLink>
    </div>
</div>
)
export default NavBar;

组件编写完成后,引入index.js,并添加 <Nav/>标签到代码中:

import React from 'react';
import ReactDOM from 'react-dom';
import {BrowserRouter as Router , Route} from 'react-router-dom';
import Jspang from './jspang';
import Jspangb from './jspangb';
import Jspangc from './jspangc';
import Nav from './nav';
ReactDOM.render(
    <Router>
        <div>
            <Nav/>
            <Route exact path="/" component={Jsdemo} />
            <Route  path="/Jsdemob" component={Jsdemob} />
            <Route  path="/Jsdemoc" component={Jsdemoc} />
        </div>
    </Router>,
    document.getElementById("app")

现在可以进行预览了,也可以顺利的切换页面内容了,说明路由已经起作用了。当然这只是路由最简单的用法


页面预览效果

NavLink中常用选项

我们初识了React的路由后,并制作了一个小案例。接下来了解一下NavLink标签上的选项。

NavLink使用样式

如果我们想给路由一个样式,这时候我们写了一CSS文件,我们如何才能使用在NavLink上?其实这并不难,不过要配置一下webpack.config.js文件。

先写一个CSS文件(我是直接在/src文件夹下直接创建的),并放在和nav.js一个文件夹下,命名为nav.css

//nav.css
.blue{
    color:blue;
}

然后用es6import方法引入到nav.js组件里,并在NavLink上加 className指定CSS类。

//nav.js
import  './nav.css';
<NavLink exact to='/' className="blue"> Jsdemoa</NavLink> |&nbsp;

现在浏览就会出现效果,因为在上一篇文章,我们已经配置了css文件和scss文件的解析。如果webpack还不能对CSS文件进行正确的解析,那你就在看一下我上一篇文章需npm安装style-loader和css-loader的知识点。

直接在NavLink上写样式

除了这种用CSS文件的方式写样式,还可以更直接写行内样式,接下来在NavLink上写样式,看下面的代码。

<NavLink exact to='/' style={{color:'red',fontSize:'50px'}}>Jsdemoa</NavLink>

这种方法虽然直观好用,但是不建议在实际开发中使用,这增加了代码的耦合度,不是一种好的编程方式。

activeClassName

作为一个链接是用激活状态的,激活状态就是当我们处在这个链接时。activeClassName就是设置激活状态的样式,它接受一个类名,我们现在nav.css顶一个active的类,把字体设置为红色。

//nav.css
.blue{
    color:blue;
}
.active{
    color:red;
}

然后改写NavLink标签。

//nav.js
import React from 'React';
import {NavLink} from 'react-router-dom';
import './nav.css';
const NavBar = () =>(
<div>
    <div>
        <NavLink exact to='/' className="blue">Jsdemoa</NavLink> |&nbsp;
        <NavLink to='/Jsdemob' activeClassName='active'>Jsdemob</NavLink> |&nbsp;
        <NavLink to='/Jsdemoc' activeClassName='active'>Jsdemoc</NavLink>
    </div>
</div>
)
export default NavBar;

现在运行就会看到点击Jsdemob的时候,Jsdemob本身是红色,Jsdemoa是蓝色,Jsdemoc没有点击是默认颜色

显示效果

404设置和跳转设置

项目中都要设置404页面,也就是当找不到这个路由时我们要跳转的页面。React中的404主要靠Switch组件来完成。接下来我们学习一下Switch相关的知识和有关跳转的知识。

Switch组件的使用

index.js页面中,在引入路由的地方,我们加入Switch的引入。

import {BrowserRouter as Router , Route , Switch} from 'react-router-dom';

编写404页面

现在需要一个统一的404页面,这里在/app文件夹下新建一个error.js文件。然后封装成组件,方便路由进行调用。

//error.js
import React from 'react';
export default class error extends React.Component{
    render(){
        return(
            <h2>404</h2>
        );
    }
}

nav.js页面中加入一个不存在的链接NavLink,为的时让它在错误的时候能自动跳转到404页面上。

//nav.js
<NavLink to='/react' activeClassName='active'>404</NavLink>

下面该主角Switch上场了,改写我们的index.js页面,改为下面的样子。

import React from 'react';
import ReactDOM from 'react-dom';
import {BrowserRouter as Router, HashRouter, MemoryRouter, Route , Switch ,Redirect} from 'react-router-dom';
import Jsdemo from './jsdemo';
import Jsdemob from './jsdemob';
import Jsdemoc from './jsdemoc';
import Nav from './nav';
import Error from './error';


ReactDOM.render(
    //basename的作用是增加一级导航目录
    <Router basename="demo">
        <div>
            <Nav/>
            <Switch>
                <Route exact path="/" component={Jsdemo} />
                <Route  path="/Jsdemob" component={Jsdemob} />
                                       /*canshu和aa是要传递的两个参数对应的名词*/
                <Route  path="/Jsdemoc/:canshu/:aa" component={Jsdemoc} />
                <Redirect from="/redirect" to="/Jsdemob" />
                <Route component={Error} />  //这个一定要在所有连接最后
            </Switch>
        </div>
    </Router>,
   document.getElementById("app")
)

然后到浏览器中进行预览,你会看到当点击404链接时,因为链接地址是我们瞎写的,但是它跳到了error.js页面。注意顺序:错误页面应该在最后面。

引入Redirect组件

index.js中引入Redirect组件

//index.js
import {BrowserRouter as Router , Route , Switch ,Redirect} from 'react-router-dom';

加入跳转链接

nav.js里加入一个准备跳转的链接,代码如下。

<NavLink to='/redirect' activeClassName='active'>Redirect</NavLink>

这时候点击这个链接,会跳转到404页面,但是我们希望跳转到jspangb页面。

****加入<Redirect>标签

index.js文件中,加入<Redirect>标签。

 <Redirect from="/redirect" to="/Jspangb" />

*from:表示来自于什么链接,也就是当链接是redirect时,我们触发跳转命令。

  • to:表示要跳转到的链接,这里是跳转到Jspangb的组件中。

写完后你可以在浏览器中查看这个跳转效果了。


查看结果

总结:设置404和跳转都要先加入Switch的支持,在制作404时一定记得要把404的Route设置到所有路由的后边。跳转时使用Redirect标签,这个很容易实现。

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

推荐阅读更多精彩内容

  • 用两张图告诉你,为什么你的 App 会卡顿? - Android - 掘金 Cover 有什么料? 从这篇文章中你...
    hw1212阅读 12,705评论 2 59
  • PS:转载请注明出处作者: TigerChain地址//www.greatytc.com/p/9a7d7...
    TigerChain阅读 63,547评论 9 218
  • Lesson11、首先确保安装了Node.js和npm依赖包管理工具2、在git上克隆官方示例程序 git clo...
    冰_心阅读 2,703评论 0 16
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,872评论 25 707
  • 昨夜红几乎没睡,红的晚餐是极简单主义,一个大西红柿,或两个奇异果,她站在阳台上独享晚餐观落日,见天边残红如血,狼吞...
    王学尔阅读 573评论 7 10