1.创建react项目

npm install -g create-react-app 全局环境

create-react-app my-app 创建项目

cd my-app 进入项目

npm start 启动

React-router介绍

什么是路由?

路由是根据不同的 url 地址展示不同的内容或页面。

React Router

一个针对React而设计的路由解决方案、可以友好的帮你解决React components 到URl之间的同步映射关系。

安装低版本react-router

卸载高版本react react-dom

npm uninstall react react-dom --save-dev

安装react-router2.0版本 安装axios

npm i react@15 react-dom@15 react-router@2 axios --save-dev

2.准备React组件

import React from 'react'

import ReactDOM from 'react-dom’

import { Router, Route, Link, hashHistory} from ‘react-router’

//react-router中定义了history这个属性 用于方便管理路由的方向

//browserHistory/ hashHistory

3.link

定义链接的组件,类似于a标签。

<Link to=“/users>users</Link> {this.props.children} //==相当于路由试图的容器

4.定义路由 index.js

 render (<Router history={hashHistory}>

 <Route path=”/" component={Demo}>

 <Route path="/home" component={Header}></Route>

 <Route path="/about" component={Con}></Route>

 </Route>

 </Router>, document.getElementById('root'))

<Route>组件有如下属性:

path(string): 路由匹配路径。(没有path属性的Route 总是会 匹配);

Component==设置该路径要加载的组件

索引 IndexRoute

指定默认情况下加载的子组件。你可以把IndexRoute想象成某个路径的index.html。

例如:

<Route path="/" component={App}> <IndexRoute component={Index}/> </Route>

样式

当路径匹配时会触发activeStyle属性。

const ACTIVE = { color: 'red' }

普通链接

<Link to="/users" activeStyle={ACTIVE}>users</Link>

地址栏传参

定义:

<Link to=“/users/1>users</Link> <Route path="/user/:xxxx" component={User}/>

取得参数:

this.props.params.xxxx==1

路径跳转(编程式路由)

在事件中进行路由路径跳转

hashHistory.push('/home')

绝对路径和重定向

相对路径:

不以/开头的路径,匹配时就会相对于父组件的路径。

<Route path="inbox" component={Inbox}> <Route path="messages/:id" component={Message} /> </Route>

访问路径:/inbox/messages/:id

绝对路径:

以/开头的路径。如果在嵌套路由中使用会跳出父组件的影响。

<Route path="inbox" component={Inbox}> <Route path=“/messages/:id" component={Message} /> </Route>

访问路径:/messages/:id

重定向:

当路径匹配from的时候,自动重定向(跳转)到to的地址上面。

<Route path=”/index" component={index}> <Redirect from=”/index/a" to=“/other" /> </Route>

从 /index/a 跳转到 /other

重定向

<IndexRedirect to="/home"/>

查询符-query

定义:

<Route path="/user/:xxxx" component={User}/>

取得参数:

this.props.params.xxxx

例如:

<Link to={{pathname:'/list',query:{id:item.goodsID} }}> <Route path="/user" component={User}/> url:/user/10086?foo=bar

this.props.params.userId 是 10086

this.props.location.query.foo 是 bar

总结:

路由的各个组件的生命周期和普通的组件生命周期是一样的。路由根据不同的url来加载和卸载不同的组件

React 路由&脚手架的更多相关文章

  1. React/VUE 脚手架2.0和3.0

    react官方脚手架 npm install -g create-react-app create-react-app my-app cd my-app npm start 区别自己对比 vue2.x ...

  2. 自制的React同构脚手架

    代码地址如下:http://www.demodashi.com/demo/12575.html Web前端世界日新月异变化太快,为了让自己跟上节奏不掉队,总结出了自己的一套React脚手架,方便日后新 ...

  3. 七天接手react项目 系列 —— react 路由

    其他章节请看: 七天接手react项目 系列 react 路由 本篇首先讲解路由原理,接着以一个基础路由示例为起点讲述路由最基础的知识,然后讲解嵌套路由.路由传参,最后讲解路由组件和一般组件的区别,以 ...

  4. react路由的安装及格式和使用方法

    react路由的安装: 在要创建项目的目录命令窗里输入: cnpm install -g create-react-app create-react-app  项目名 在创建好的项目目录命令窗里输入: ...

  5. react router @4 和 vue路由 详解(七)react路由守卫

    完整版:https://www.cnblogs.com/yangyangxxb/p/10066650.html 12.react路由守卫? a.在之前的版本中,React Router 也提供了类似的 ...

  6. react路由嵌套

    所谓的嵌套路由就是在某些以及路由下面存在二级路由,这些二级路由除了公用一级路由导航模块外,还公用当前的二级路由的导航模块,也就是部分进行了切换,要实现嵌套路由,首先回顾之前的内容,实现基本的react ...

  7. react路由配置(未完)

    React路由 React推了两个版本 一个是react-router 一个是react-router-dom 个人建议使用第二个 因为他多了一个Link组件 Npm install react-ro ...

  8. React路由-基础篇

    React-Router-DOM ReactRouter网址, 安装 -npmjs找到react-router-dom -yarn add react-router-dom 基本使用方法 1.创建一个 ...

  9. react 路由 react-router@3.2.1

    react路由,4.x的差异还是比较大,暂时还是3.x的版本 安装: npm install -S react-router@3.x 配置: import { Router, Route, hashH ...

随机推荐

  1. markdown常用方法

    Markdown格式的普及流行要归功于Github和StackOverflow的流行,随着它们越来越流行,它们支持的Markdown格式也越来越流行. 1.优点 1.Markdown通过内容和样式相分 ...

  2. Djangou中使用cookie和session

    一.会话跟踪 我们先需要了解是什么是会话!可以把会话理解为客户端与服务器之间的一次会话,在一次会话中可能会包含多次请求和响应,例如你给10086打个电话,你就是客户端,而10086服务人员就是服务器, ...

  3. 入门webpack,看这篇就够了

    什么是webpack? 官网给出的概念是:本质上,webpack 是一个现代 JavaScript 应用程序的静态模块打包器(module bundler).当 webpack 处理应用程序时,它会递 ...

  4. go 学习笔记之工作空间

    搭建好 Go 的基本环境后,现在可以正式开始 Go 语言的学习之旅,初学时建议在默认的 GOPATH 工作空间规范编写代码,基本目录结构大概是这个样子. . |-- bin | `-- hello.e ...

  5. 四、Python基础(1)

    目录 四.Python基础(1) 四.Python基础(1) 1.什么是变量? 一种变化的量,量是记录世界上的状态,变指得是这些状态是会变化的. 2.为什么有变量? 因为计算机程序的运行就是一系列状态 ...

  6. 【有容云】PPT | 容器落地之二三事儿

    编者注: 本文为10月29日有容云联合创始人兼研发副总裁江松在 Docker Live时代线下系列-广州站中演讲的PPT,本次线下沙龙为有容云倾力打造Docker Live时代系列主题线下沙龙,每月一 ...

  7. jenkins部署自动化项目备注

    一.定时任务部署: 第一个*表示分钟,取值0~59 第二个*表示小时,取值0~23 第三个*表示一个月的第几天,取值1~31 第四个*表示第几月,取值1~12 第五个*表示一周中的第几天,取值0~7, ...

  8. 【Java例题】8.1手工编写加法器的可视化程序

    1. 手工编写加法器的可视化程序. 一个Frame窗体容器,布局为null,三个TextField组件,一个Button组件. Button组件上添加ActionEvent事件监听器ActionLis ...

  9. 【TCP/IP】ICMP协议

    ICMP协议有两种报文: 1,查询报文 2,差错报文

  10. javaweb基础整理随笔------jstl与el表达式

    虽然jsp中可以写java代码,但是现在不推荐这么做. jsp虽然本质是servlet,但是主要作用只是视图,视图的任务就是显示响应,而不是在JSP中做任何关于程序控制和业务逻辑的事情.所以在JSP页 ...