React-router4路由監(jiān)聽的實現(xiàn)
React-router 4
React Router4是一個純React重寫的包,現(xiàn)在的版本中已不需要路由配置,一切皆組件。
問題出發(fā)點
最近在一個新的H5項目中使用了react router 4 ("react-router-dom": "^4.2.2"),項目中的一部分頁面是需要給app客戶端的同學(xué)使用,這樣H5項目中的title就不能一成不變,需要顯示對應(yīng)頁面的title,所以,我們就需要去監(jiān)聽路由變動來更改title。
思路
在react中,例如:在父路由中有兩個子路由,兩個子路由組件的內(nèi)容都屬于父路由中的一部分,通過切換子路由來顯示不同內(nèi)容,這種情況下,父組件中的生命周期函數(shù)componentWillUpdate都會在切換子路由時被觸發(fā)。按照這個思路結(jié)合react-router 4一切皆組件的特性,我們可以用一個IndexPage組件來放置所有的一級路由(其他多級路由就可以放到對應(yīng)一級路由組件中),當(dāng)我們切換路由是,就可以在這個IndexPage組件中實時監(jiān)聽路由的變動了。
項目目錄結(jié)構(gòu)

src/app.js
...
export default class App extends Component {
render() {
return (
<Router>
<Route path="/" component={IndexPage}/>
</Router>
)
}
}
src/pages/index.js
...
export default class IndexPage extends Component {
componentDidMount() {
this.updateTitle(this.props);
}
componentWillUpdate(nextProps) {
this.updateTitle(nextProps);
}
updateTitle = (props) => {
routes.forEach(route => {
if (route.path === props.location.pathname) {
document.title = route.title;
}
})
}
render() {
return (
<div className="index-page">
<Switch>
...
項目一級路由
...
</Switch>
</div>
)
}
}
在這個組件中,當(dāng)路由變動,我們都能實時監(jiān)聽,獲取路由來改變title
總結(jié)
利用react-router 4一切皆組件的特性和生命周期函數(shù)來監(jiān)聽路由變動
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
React?中?memo?useMemo?useCallback?到底該怎么用
在React函數(shù)組件中,當(dāng)組件中的props發(fā)生變化時,默認(rèn)情況下整個組件都會重新渲染。換句話說,如果組件中的任何值更新,整個組件將重新渲染,包括沒有更改values/props的函數(shù)/組件。在react中,我們可以通過memo,useMemo以及useCallback來防止子組件的rerender2022-10-10
React 使用recharts實現(xiàn)散點地圖的示例代碼
這篇文章主要介紹了React 使用recharts實現(xiàn)散點地圖的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-12-12
React配置Redux并結(jié)合本地存儲設(shè)置token方式
這篇文章主要介紹了React配置Redux并結(jié)合本地存儲設(shè)置token方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-01-01
react中的watch監(jiān)視屬性-useEffect介紹
這篇文章主要介紹了react中的watch監(jiān)視屬性-useEffect使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09
詳解React項目的服務(wù)端渲染改造(koa2+webpack3.11)
本篇文章主要介紹了詳解React項目的服務(wù)端渲染改造(koa2+webpack3.11),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-03-03

