react router零基礎(chǔ)使用教程
安裝
既然學(xué)習(xí) react router 就免不了運(yùn)行 react
安裝 react
npx create-react-app my-app
cd my-app
npm start
安裝 react router
npm install react-router-dom
如果一切正常,就讓我們打開 index.js 文件。
配置路由
引入 react-router-dom 的 RouterProvider
import {RouterProvider} from 'react-router-dom'
設(shè)置
const root = ReactDOM.createRoot(document.getElementById('root')); root.render( <React.StrictMode> <RouterProvider router={routers}></RouterProvider> </React.StrictMode> );
這里的 React.StrictMode 代表以嚴(yán)格模式執(zhí)行其包含的內(nèi)容。
為了管理路由,讓我們再創(chuàng)建一個 root.js 文件
內(nèi)容如下:
文件:router.js
import {createBrowserRouter} from 'react-router-dom' import App from '../App.js' const router = createBrowserRouter ([ { path:'/', element:<App />, } ]) export default router;
添加一個新頁面測試路由
新建文件:
test.js
export default function Test(){ return( <div>測試頁面</div> ) }
在 router.js 引入
import {createBrowserRouter} from 'react-router-dom' import App from '../App.js' import Test from '../test.js' const router = createBrowserRouter ([ { path:'/', element:<App />, }, { path:'/test', element:<Test /> } ]) export default router;
保存
在瀏覽器訪問 http://localhost:3000/test
你應(yīng)該可以看到:
配置未找到的路由
現(xiàn)在我們有 App.js 和 test.js 兩個頁面,如果訪問 http://localhost:3000/hello 會出現(xiàn)什么呢?
這是內(nèi)置的頁面,提醒用戶沒有找到頁面。
接下來使用美化或者自定義的頁面:
創(chuàng)建文件:
error.js
export default function Error(){ return ( <h1>Page not found</h1> ) }
使用 errorElement屬性 對應(yīng)這個頁面:
import {createBrowserRouter} from 'react-router-dom' import App from '../App.js' import Test from '../test.js' import Error from '../error.js' const router = createBrowserRouter ([ { path:'/', element:<App />, errorElement:<Error /> }, { path:'/test', element:<Test /> } ]) export default router;
繼續(xù)請求 http://localhost:3000/hello
我們剛才自定義的頁面成功展示出來了。
跳轉(zhuǎn)頁面
跳轉(zhuǎn)頁面有很多,這里取兩種方式,一是通過 dom 標(biāo)簽,二是通過js
通過 js
使用 useNavigate 跳轉(zhuǎn)頁面:
看起來就像這樣:
test.js
import { useNavigate } from "react-router-dom"; function Test () { const navigate = useNavigate(); function toTest2(){ navigate("/test2",{ state:'anny' }); } return( <div onClick={toTest2}>跳轉(zhuǎn)頁面</div> ) } export default Test
使用 useLocation 接收值:
import {useLocation} from 'react-router-dom' export default function Test2(){ let location = useLocation(); return ( <div>頁面Test2 接收到的值為 {location.state}</div> ) }
通過 dom
通過 Link 傳值跳轉(zhuǎn):
import {Link } from "react-router-dom"; function Test () { return( <div> <Link to="/test2" state={'anny'} >跳轉(zhuǎn)頁面</Link> </div> ) } export default Test
使用 useLocation 接收值:
import {useLocation} from 'react-router-dom' export default function Test2(){ let location = useLocation(); return ( <div>頁面Test2 接收到的值為 {location.state}</div> ) }
嵌套頁面
平時寫管理后臺,經(jīng)常會看到左右分布的布局,如果僅僅依靠 1-5 節(jié)的內(nèi)容肯定很難實現(xiàn),接下來看一下 根布局。
根布局使用 :
創(chuàng)建一個 父頁面,父頁面放置兩個 鏈接:
parent.js
import { Link, Outlet } from "react-router-dom"; function Parent(){ return( <div> <Link to={'/parent/page1'}>show page1</Link> <Link to={'/parent/page2'}>show page2</Link> <Outlet></Outlet> </div> ) } export default Parent;
繼續(xù)創(chuàng)建 兩個頁面 page1.js page2.js
page1.js
function Page1(){ return( <div>i am page1</div> ) } export default Page1;
page2.js
function Page2(){ return( <div>i am page2</div> ) } export default Page2;
修改我們的 router.js 文件:
import {createBrowserRouter} from 'react-router-dom' import App from '../App.js' import Test from '../test.js' import Error from '../error.js' import Parent from '../parent.js' import Page1 from '../page1.js' import Page2 from '../page2.js' const router = createBrowserRouter ([ { path:'/', element:<App />, errorElement:<Error />, }, { path:'/test', element:<Test /> }, { path:'/parent', element:<Parent />, children:[ { path:'/parent/page1', element:<Page1 /> }, { path:'/parent/page2', element:<Page2 /> } ] } ]) export default router;
到這里還差一步,就是使用重要的標(biāo)簽 <Outlet>
修改我們的父頁面
parent.js
import { Link, Outlet } from "react-router-dom"; function Parent(){ return( <div> <Link to={'/parent/page1'}>show page1</Link> <Link to={'/parent/page2'}>show page2</Link> <Outlet></Outlet> </div> ) } export default Parent;
保存:
接下來訪問 http://localhost:3000/parent 你將看到:
分別點擊 show page1
和 show page2
你將看到不同的效果。
如果你想將第一個子組件默認(rèn)展示出來,你可以將 router.js 改成如下:
{ path:'/parent', element:<Parent />, children:[ { path:'/parent', element:<Page1 /> }, { path:'/parent/page2', element:<Page2 /> } ] }
再看一下效果:
到此這篇關(guān)于react router零基礎(chǔ)使用教程的文章就介紹到這了,更多相關(guān)react router內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue路由權(quán)限和按鈕權(quán)限的實現(xiàn)示例
本文主要介紹了vue路由權(quán)限和按鈕權(quán)限的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04解決element DateTimePicker+vue彈出框只顯示小時
這篇文章主要介紹了解決element DateTimePicker+vue彈出框只顯示小時,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03vue開發(fā)移動端使用better-scroll時click事件失效的解決方案
這篇文章主要介紹了vue開發(fā)移動端使用better-scroll時click事件失效的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07