欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

react router零基礎(chǔ)使用教程

 更新時間:2022年09月26日 17:04:23   作者:十九(一拖再拖)  
React-Router 路由庫,是官方維護(hù)的路由庫,事實上也是唯一可選的路由庫。它通過管理 URL,實現(xiàn)組件的切換和狀態(tài)的變化,開發(fā)復(fù)雜的應(yīng)用幾乎肯定會用到

安裝

既然學(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 page1show 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)示例

    本文主要介紹了vue路由權(quán)限和按鈕權(quán)限的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04
  • Vue實現(xiàn)Chrome小恐龍游戲的示例代碼

    Vue實現(xiàn)Chrome小恐龍游戲的示例代碼

    Google 給 Chrome 瀏覽器加了一個有趣的彩蛋,本文就詳細(xì)的介紹一下Vue實現(xiàn)Chrome小恐龍游戲的示例代碼,具有一定的參考價值,感興趣的可以了解一下
    2022-04-04
  • vue+webpack 更換主題N種方案優(yōu)劣分析

    vue+webpack 更換主題N種方案優(yōu)劣分析

    這篇文章主要介紹了vue+webpack 更換主題N種方案優(yōu)劣分析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • 解決element DateTimePicker+vue彈出框只顯示小時

    解決element DateTimePicker+vue彈出框只顯示小時

    這篇文章主要介紹了解決element DateTimePicker+vue彈出框只顯示小時,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • Vue.js高效前端開發(fā)

    Vue.js高效前端開發(fā)

    Vue是構(gòu)建Web界面的JavaScript庫,原稱為Vue.js,它可以通過簡潔的API來提供高效的數(shù)據(jù)綁定和靈活的組件系統(tǒng),本文詳細(xì)介紹了Vue的使用安裝和相關(guān)知識,有興趣的同學(xué)可以參考借鑒
    2023-03-03
  • vue開發(fā)移動端使用better-scroll時click事件失效的解決方案

    vue開發(fā)移動端使用better-scroll時click事件失效的解決方案

    這篇文章主要介紹了vue開發(fā)移動端使用better-scroll時click事件失效的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • vue實現(xiàn)動態(tài)路由詳細(xì)

    vue實現(xiàn)動態(tài)路由詳細(xì)

    我們開發(fā)后臺管理系統(tǒng)過程中,會由不同的人操作系統(tǒng),有admin(管理員)、superAdmin(超管),及各種運(yùn)營、財務(wù)人員。為了區(qū)別這些人員,會給不同的人分配不一樣的角色來展示不同的菜單,這就必須要通過動態(tài)路由來實現(xiàn)。下面就來介紹vue實現(xiàn)動態(tài)路由,需要的朋友可參考一下
    2021-10-10
  • vue2與vue3下如何訪問使用public下的文件

    vue2與vue3下如何訪問使用public下的文件

    這篇文章主要介紹了vue2與vue3下如何訪問使用public下的文件,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • vue3輸入框生成的時候如何自動獲取焦點詳解

    vue3輸入框生成的時候如何自動獲取焦點詳解

    記錄一下自己最近開發(fā)vue3.0的小小問題,下面這篇文章主要給大家介紹了關(guān)于vue3輸入框生成的時候如何自動獲取焦點的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • Vue項目中設(shè)置背景圖片方法

    Vue項目中設(shè)置背景圖片方法

    下面小編就為大家分享一篇Vue項目中設(shè)置背景圖片方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02

最新評論