官网文档
https://reacttraining.com/react-router/core/guides/philosophy
data:image/s3,"s3://crabby-images/28fff/28fff0e465756e966a6701c126276817b22755db" alt=""
data:image/s3,"s3://crabby-images/affdb/affdb5d318baa115ac5a0050e5230ca3de534a06" alt=""
页面路由
data:image/s3,"s3://crabby-images/94ba9/94ba9b17d48a14f3b1eefc84bd4ba85f08e3c157" alt=""
Hash 路由
data:image/s3,"s3://crabby-images/c0e61/c0e614933e45f46b135f164571b0cc8062f40108" alt=""
data:image/s3,"s3://crabby-images/bad18/bad185a8a0f6112d469a16426a17beb35b7acf8a" alt=""
H5路由
只对后退记录有效
data:image/s3,"s3://crabby-images/2d414/2d414e593617dea532e7cf5b11c3596d9fcbb6c4" alt=""
data:image/s3,"s3://crabby-images/d16d1/d16d10d87e9fc8a188320ca316dc4d7c990b8963" alt=""
// 页面路由
window.location.href = 'http://www.baidu.com';
history.back();
// hash 路由
window.location = '#hash';
window.onhashchange = function(){
console.log('current hash:', window.location.hash);
}
// h5 路由
// 推进一个状态
history.pushState('name', 'title', '/path');
// 替换一个状态
history.replaceState('name', 'title', '/path');
// popstate
window.onpopstate = function(){
console.log(window.location.href);
console.log(window.location.pathname);
console.log(window.location.hash);
console.log(window.location.search);
}
data:image/s3,"s3://crabby-images/7f66f/7f66fd5135b363dbe363fa956b0565650404500b" alt=""
// react-router
import React from 'react';
import ReactDOM from 'react-dom';
import { HashRouter as Router, Switch, Route, Link } from 'react-router-dom'
class A extends React.Component{
constructor(props){
super(props)
}
render(){
return (
<div>
Component A
<Switch>
<Route exact path={`${this.props.match.path}`} render={(route) => {
return <div>当前组件是不带参数的A</div>
}}/>
<Route path={`${this.props.match.path}/sub`} render={(route) => {
return <div>当前组件是Sub</div>
}}/>
<Route path={`${this.props.match.path}/:id`} render={(route) => {
return <div>当前组件是带参数的A, 参数是:{route.match.params.id}</div>
}}/>
</Switch>
</div>
)
}
}
class B extends React.Component{
constructor(props){
super(props)
}
render(){
return <div>Component B</div>
}
}
class Wrapper extends React.Component{
constructor(props){
super(props)
}
render(){
return (
<div>
<Link to="/a">组件A</Link>
<br/>
<Link to="/a/123">带参数的组件A</Link>
<br/>
<Link to="/b">组件B</Link>
<br/>
<Link to="/a/sub">/a/sub</Link>
{this.props.children}
</div>
);
}
}
ReactDOM.render(
<Router>
<Wrapper>
<Route path="/a" component={A}/>
<Route path="/b" component={B}/>
</Wrapper>
</Router>,
document.getElementById('app')
);
通过以上代码,首先演示 Hash 路由
data:image/s3,"s3://crabby-images/4d52e/4d52ef76b47f7c07b30b31c335103ebb05da5ab0" alt=""
再演示 H5路由,即修改此处
data:image/s3,"s3://crabby-images/c2121/c2121572e8c4f8f1e2bf89d6ef984a12712770bd" alt=""
data:image/s3,"s3://crabby-images/42036/42036b7a99587272ff866a02e7989ac106f35cbe" alt=""
将参数传给组件
data:image/s3,"s3://crabby-images/8844f/8844fec3e7ee003b1250d19df8b404c3713a974b" alt=""
网友评论