React Router中Link和NavLink的學習心得總結
React Router Link和NavLink的學習
Link
現(xiàn)在,我們應用需要在各個頁面間切換,如果使用錨點元素實現(xiàn),在每次點擊時,頁面被重新加載,React Router提供了<Link>組件用來避免這種狀況發(fā)生。
當 你點擊<Link>時,url會更新,組件會被重新渲染,但是頁面不會重新加載
先看個例子:
// to為string
<Link to="/about">關于</Link>
// to為obj
<Link to={{
pathname: '/courses',
search: '?sort=name',
hash: '#the-hash',
state: { fromDashboard: true }
}}/>
// replace
<Link to="/courses" replace /><Link>使用to參數(shù)來描述需要定位的頁面。它的值既可是字符串,也可以是location對象(包含pathname、search、hash、與state屬性)如果其值為字符串,將會被轉換為location對象
replace(bool):為 true 時,點擊鏈接后將使用新地址替換掉訪問歷史記錄里面的原地址;為 false 時,點擊鏈接后將在原有訪問歷史記錄的基礎上添加一個新的紀錄。默認為 false;
點擊Link后,路由系統(tǒng)發(fā)生了什么?
Link 組件最終會渲染為 HTML 標簽 <a>,它的 to、query、hash 屬性會被組合在一起并渲染為 href 屬性。
雖然 Link 被渲染為超鏈接,但在內部實現(xiàn)上使用腳本攔截了瀏覽器的默認行為,然后調用了history.pushState 方法(注意,文中出現(xiàn)的 history 指的是通過 history 包里面的 create*History 方法創(chuàng)建的對象,window.history 則指定瀏覽器原生的 history 對象,由于有些 API 相同,不要弄混)。
history 包中底層的 pushState 方法支持傳入兩個參數(shù) state 和 path,在函數(shù)體內有將這兩個參數(shù)傳輸?shù)?createLocation 方法中,返回 location 的結構如下:
location = {
pathname, // 當前路徑,即 Link 中的 to 屬性
search, // search
hash, // hash
state, // state 對象
action, // location 類型,在點擊 Link 時為 PUSH,瀏覽器前進后退時為 POP,調用 replaceState 方法時為 REPLACE
key, // 用于操作 sessionStorage 存取 state 對象
};系統(tǒng)會將上述 location 對象作為參數(shù)傳入到 TransitionTo 方法中,然后調用 window.location.hash 或者window.history.pushState() 修改了應用的 URL,這取決于你創(chuàng)建 history 對象的方式。
同時會觸發(fā)history.listen 中注冊的事件監(jiān)聽器。
NavLink
<NavLink>是<Link>的一個特定版本,會在匹配上當前的url的時候給已經(jīng)渲染的元素添加參數(shù),組件的屬性有
activeClassName(string):設置選中樣式,默認值為activeactiveStyle(object):當元素被選中時,為此元素添加樣式exact(bool):為true時,只有當導致和完全匹配class和style才會應用strict(bool):為true時,在確定為位置是否與當前URL匹配時,將考慮位置pathname后的斜線isActive(func)判斷鏈接是否激活的額外邏輯的功能
看例子就懂了:
// activeClassName選中時樣式為selected
<NavLink
to="/faq"
activeClassName="selected"
>FAQs</NavLink>
// 選中時樣式為activeStyle的樣式設置
<NavLink
to="/faq"
activeStyle={{
fontWeight: 'bold',
color: 'red'
}}
>FAQs</NavLink>
// 當event id為奇數(shù)的時候,激活鏈接
const oddEvent = (match, location) => {
if (!match) {
return false
}
const eventID = parseInt(match.params.eventID)
return !isNaN(eventID) && eventID % 2 === 1
}
<NavLink
to="/events/123"
isActive={oddEvent}
>Event 123</NavLink>總結
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
解決React報錯No duplicate props allowed
這篇文章主要為大家介紹了React報錯No duplicate props allowed解決方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-12-12
React?Native?中處理?Android?手機吞字的解決方案
這篇文章主要介紹了React?Native?中處理?Android?手機吞字的解決方案,作者在 React Native 0.67.4 環(huán)境下,編寫了一個小 demo 來復現(xiàn)這個問題,需要的朋友可以參考下2022-08-08
react-redux的connect與React.forwardRef結合ref失效的解決
這篇文章主要介紹了react-redux的connect與React.forwardRef結合ref失效的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05
使用VScode 插件debugger for chrome 調試react源碼的方法
這篇文章主要介紹了使用VScode 插件debugger for chrome 調試react源碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-09-09

