react-router中Link標(biāo)簽和a標(biāo)簽有什么區(qū)別
1.功能:
- Link:在單頁應(yīng)用程序(SPA)中提供導(dǎo)航,而不會導(dǎo)致頁面重新加載。當(dāng)用戶點(diǎn)擊鏈接時,React會阻止瀏覽器默認(rèn)的頁面刷新行為,并且使用
react-router提供的導(dǎo)航方式,只更新URL并渲染對應(yīng)的組件,從而實現(xiàn)單頁面應(yīng)用(SPA)的效果。。 - a:單擊時會導(dǎo)致完整頁面重新加載,導(dǎo)航到新
URL。
2.性能:
- Link:由于不會導(dǎo)致頁面重新加載,因此它提供更好的用戶體驗,特別是在
SPA中。它提高了性能,因為避免了不必要的網(wǎng)絡(luò)請求。 - a:完整頁面重新加載會導(dǎo)致較慢的用戶體驗,因為需要從服務(wù)器獲取新頁面。
3.無障礙:
- Link:提供更好的無障礙性,因為它可以通過鍵盤聚焦和激活。
- a:可能不那么無障礙,因為它不提供與按鈕或其他交互式元素相同的鍵盤導(dǎo)航和焦點(diǎn)行為。
使用Link標(biāo)簽
屬性描述
to
跳轉(zhuǎn)鏈接的路徑,如 /users/123。
query
已經(jīng)轉(zhuǎn)化成字符串的鍵值對的對象。
hash
URL 的 hash 值,如 #a-hash。
注意:React Router 目前還不能管理滾動條的位置,并且不會自動滾動到 hash 對應(yīng)的元素上。如果需要管理滾動條位置,可以使用 scroll-behavior 這個庫。
state
保存在 location 中的 state。
activeClassName
當(dāng)某個 route 是激活狀態(tài)時,<Link> 可以接收傳入的 className。失活狀態(tài)下是默認(rèn)的 class。
activeStyle
當(dāng)某個 route 是激活狀態(tài)時,可以將樣式添加到鏈接元素上。
onClick(e)
自定義點(diǎn)擊事件的處理方法。如處理 <a> 標(biāo)簽一樣 - 調(diào)用 e.preventDefault() 來防止過度的點(diǎn)擊,同時 e.stopPropagation() 可以阻止冒泡的事件。
其他
你也可以在標(biāo)簽上傳入一些你想要的 props,如 title,id,className 等等。
link使用示例:
import { BrowserRouter as Router, Route, Link } from 'react-router-dom';
const Home = () => <h2>Home</h2>;
const About = () => <h2>About</h2>;
const App = () => (
<Router>
<div>
<nav>
<ul>
<li>
<Link to="/">Home</Link>
</li>
<li>
<Link to="/about/">About</Link>
</li>
</ul>
</nav>
<Route path="/" exact component={Home} />
<Route path="/about/" component={About} />
</div>
</Router>
);
export default App;區(qū)別
<Link> 是 react-router 里實現(xiàn)路由跳轉(zhuǎn)的鏈接,一般配合 <Route> 使用,react-router 會接管Link 的默認(rèn)鏈接跳轉(zhuǎn)行為,區(qū)別于傳統(tǒng)的頁面跳轉(zhuǎn),<Link> 的“跳轉(zhuǎn)”行為只會觸發(fā)相匹配的 <Route> 對應(yīng)的頁面內(nèi)容更新,而不會刷新整個頁面。
而 <a> 標(biāo)簽就是普通的超鏈接了,用于從當(dāng)前頁面跳轉(zhuǎn)到 href 指向的另一個頁面(非錨點(diǎn)情況)。
對比<a>,Link組件避免了不必要的重渲染,react-router只更新變化的部分從而減少DOM性能消耗,react的創(chuàng)新之處在于,它利用虛擬DOM的概念和diff算法實現(xiàn)了對頁面的"按需更新",react-router很好地繼承了這一點(diǎn)
Link做了3件事情:
1、如果Link上定義了onClick方法,則執(zhí)行該onclick方法
2、click的時候阻止a標(biāo)簽?zāi)J(rèn)事件(這樣子點(diǎn)擊<a href="/abc">123</a>就不會跳轉(zhuǎn)和刷新頁面)
3、再取得跳轉(zhuǎn)href(即是to),用history(前端路由兩種方式之一,history & hash)跳轉(zhuǎn),此時只是鏈接變了,并沒有刷新頁面
到此這篇關(guān)于react-router中Link標(biāo)簽和a標(biāo)簽有什么區(qū)別的文章就介紹到這了,更多相關(guān)react-router Link標(biāo)簽和a標(biāo)簽內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
react 跳轉(zhuǎn)后路由變了頁面沒刷新的解決方案
最近在學(xué)習(xí)React的過程中遇到了路由跳轉(zhuǎn)后頁面不刷新的問題,本文就詳細(xì)的介紹一下解決方法,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-06-06
react配合antd組件實現(xiàn)的管理系統(tǒng)示例代碼
這篇文章主要介紹了react配合antd組件實現(xiàn)的管理系統(tǒng)示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-04-04
解決react中useState狀態(tài)異步更新的問題
本文主要介紹了react中useState狀態(tài)異步更新的問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07
React如何使用Portal實現(xiàn)跨層級DOM渲染
Portal 就像是一個“傳送門”,能讓你把組件里的元素“傳送到”其他 DOM 節(jié)點(diǎn)下面去渲染,下面小編就來和大家簡單介紹一下具體的使用方法吧2025-04-04
React 如何使用時間戳計算得到開始和結(jié)束時間戳
這篇文章主要介紹了React 如何拿時間戳計算得到開始和結(jié)束時間戳,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-09-09
使用React和Redux Toolkit實現(xiàn)用戶登錄功能
在React中,用戶登錄功能是一個常見的需求,為了實現(xiàn)該功能,需要對用戶輸入的用戶名和密碼進(jìn)行驗證,并將驗證結(jié)果保存到應(yīng)用程序狀態(tài)中,在React中,可以使用Redux Toolkit來管理應(yīng)用程序狀態(tài),從而實現(xiàn)用戶登錄功能,需要詳細(xì)了解可以參考下文2023-05-05

