目录:

1、demo:NavLink 标签跳转

2、标签渲染路由组件时,获取url参数

3、编程式跳转

参考文档

  1)https://reacttraining.com/react-router/web/guides/quick-start

  2)http://react-guide.github.io/react-router-cn/index.html

1、demo:NavLink 标签跳转  <-- 返回

  index.jsx

import React from 'react'
import ReactDOM from 'react-dom'
import { BrowserRouter as Router } from 'react-router-dom' import App from './components/App.jsx' ReactDOM.render(
<Router><App /></Router>,
document.getElementById('root'))

  App.jsx

import React from 'react'
import { NavLink, Switch, Route, Redirect } from 'react-router-dom' import About from '../views/about.jsx'
import Home from '../views/home.jsx'
import User from '../views/user.jsx' export default class App extends React.Component {
state = {
user: {
id: 1,
name: 'zs'
}
}
render() {
const {user} = this.state
return (
<div>
<h3>tab切换</h3>
{/* 导航链接 */}
<NavLink to='/about'>About</NavLink><br/>
<NavLink to='/home'>Home</NavLink><br/>
<NavLink to='/user/1'>User</NavLink> <h3>组件</h3>
<Switch>
{/* <Route path='/about' component={About} />
<Route path='/home' component={Home} /> */}
<Route path='/about'><About /></Route>
<Route path='/home'><Home /></Route>
<Route path='/user/:id'><User user={user}/></Route>
<Redirect strict from='' to='/about' />
</Switch>
</div>
)
}
}

  User.jsx

import React from 'react'

export default class User extends React.Component {
render() {
return (
<div>
user组件
{this.props.user.id + "--" + this.props.user.name}
</div>
)
}
}

  about.jsx

import React from 'react'

export default class About extends React.Component {
render() {
return (
<div>
about组件
</div>
)
}
}

2、标签渲染路由组件时,获取url参数  <-- 返回

  2.1、使用this.props.match

<Route path='/user/:id' component={User}></Route>

  使用这种标签渲染路由组件时,获取url参数:this.props.match.params.占位变量

const {id} = this.props.match.params
console.log(this.props)
console.log(`id=${id}`)

  打印结果:

  

  2.2、使用React Hook: useRouteMatch, useParams

<Route path='/user/:id'><User user={user}/></Route>

  当这样使用时,不能够通过this.props.match.params.占位变量的方式来获取url参数;此时可以使用useRouteMatch, useParams(配合function组件使用)

import React from 'react'
import { useRouteMatch, useParams } from
'react-router-dom'
export default function User(props) {
let match = useRouteMatch()
console.log(match) let { id } = useParams()
console.log(`path parameter id = ${id}`) return (
<div>
user组件
{props.user.id + "--" + props.user.name}
</div>
)
}

  在非函数组件里使用React Hook,报错:

Error: Invalid hook call. Hooks can only be called inside of the body of a function component. This could happen for one of the following reasons:
1. You might have mismatching versions of React and the renderer (such as React DOM)
2. You might be breaking the Rules of Hooks
3. You might have more than one copy of React in the same app
See https://fb.me/react-invalid-hook-call for tips about how to debug and fix this problem.

3、编程式跳转  <-- 返回

  3.1、对下面这样注册路由的方式,可以直接在路由组件中使用this.props.history.push('/路由')

<Route path='/user/:id' component={User}></Route>

  3.2、<Route path='/home'><Home /></Route>这样注册路由的方式,父组件传递history给子组件使用

  App.jsx

import React from 'react'
import { NavLink, Switch, Route, Redirect } from 'react-router-dom' import { useHistory } from "react-router-dom"; import About from '../views/about.jsx'
import Home from '../views/home.jsx'
import User from '../views/user.jsx' export default function App() {
let history = useHistory(); return (
<div>
<h3>tab切换</h3>
{/* 导航链接 */}
<NavLink to='/about'>About</NavLink><br />
<NavLink to='/home'>Home</NavLink><br />
<NavLink to='/user/1'>User</NavLink> <h3>组件</h3>
<Switch>
<Route path='/about'><About history={history} /></Route>
<Route path='/home'><Home history={history} /></Route>
<Route path='/user/:id'><User history={history} /></Route>
<Redirect strict from='' to='/about' />
</Switch>
</div>
) }

  user.jsx

import React from 'react'
import { NavLink, Switch, Route, Redirect } from 'react-router-dom' import UserAdd from './UserAdd.jsx'
import UserList from './UserList.jsx'
import UserEdit from './UserEdit.jsx' export default class User extends React.Component {
render() { return (
<div>
user组件<br />
{console.log(this.props)} {/* 导航链接 */} F
<NavLink to='/user/list'>UserList</NavLink> <button onClick={this.listClickHandler}>to list</button><br />
<NavLink to='/user/add'>UserAdd</NavLink> <button onClick={this.addClickHandler}>to add</button><br />
<NavLink to='/user/edit/110'>UserEdit</NavLink> <button onClick={this.editClickHandler}>to edit</button> <h3>组件</h3>
<Switch>
<Route path='/user/list'><UserList /></Route>
<Route path='/user/add'><UserAdd /></Route>
<Route path='/user/edit/:id'><UserEdit /></Route> {/* <Route path='/user/list' component={UserList}></Route>
<Route path='/user/add' component={UserAdd}></Route>
<Route path='/user/edit/:id' component={UserEdit}></Route> */}
{/* <Redirect strict from='' to='/about' /> */}
</Switch> </div>
)
} listClickHandler = () => {
this.props.history.push('/user/list')
}
addClickHandler = () => {
this.props.history.push('/user/add')
}
editClickHandler = () => {
this.props.history.push('/user/edit/110')
}
}

----

最新文章

  1. treap 模版
  2. git push error: A Contributor Agreement must be completed before uploading
  3. SVD分解的理解[转载]
  4. (转)Spark安装与学习
  5. [AHOI2015 Junior] [Vijos P1943] 上学路上 【容斥+组合数】
  6. VB.NET中LINQ TO List泛型查询语句(分组,聚合函数)
  7. SpringBoot运行原理
  8. 变态的IE
  9. Python学习(三十二)—— Django之视图系统
  10. Spring 出现Could not resolve placeholder问题的解决方法
  11. 英语口语练习系列-C13-聚会
  12. js自己总结的小东西(打印出来方便学习)
  13. SpringAOP 注解方式
  14. 一次Linux服务器被入侵和删除木马程序的经历
  15. C++面试题:list和vector有什么区别
  16. 使用struts框架后的404错误
  17. web项目传classes目录项目正常,打包成jar不能运行。
  18. SpringIDE的安装
  19. metasploit出错信息:can&#39;t allocate memory
  20. Vue.js图片预览插件

热门文章

  1. AtCoder AISing Programming Contest 2019 Task D. Nearest Card Game
  2. HDU 4417-Super Mario-线段树+离线
  3. macos catalina安装python3
  4. opencv实现人脸识别(四) 人脸识别模块
  5. easyui datagrid 合并相同行
  6. 怎样设置HTTP请求头Header
  7. Python字符串的常用方法总结
  8. 【Java并发】线程通信
  9. Mac上的redis安装与jedis入门
  10. PHP判断是否有Get参数的方法