主頁 > 企業開發 > React學習時,outlet配置(token判定,頁面path監聽)

React學習時,outlet配置(token判定,頁面path監聽)

2023-07-01 08:42:58 企業開發

盡管寫過 outlet 路由的配置,
考慮到 token 判定和 路由頁 變更,我不了解v6是不是有更詳解的做法,
決定調一下配置,期望 在任何頁面異步更新時,token 都可以在跳轉前 被檢測到,防止無 token 跳轉發生,

補上404頁面( 地址欄 頁面不存在時,展示404頁面 )

為 src 檔案配置 v6版本:路由子組件

App.js
import { HashRouter, Routes, Route } from 'react-router-dom';
import Main from './main';
import Login from './page/login'
import Home from './page/home/home'
import About from './page/about/about'
import Integrated from './page/integrated/integrated'
import Sidebar from './page/sidebar/sidebar'
import Latent from './page/latent/latent'
import Particulars from './page/particulars/particulars'
import SecurityCheck from './page/securityCheck/securityCheck'
import FourPage from './compoment/404';
function App() {
  {/* 默認顯示頁面將不需要填寫路徑 ,子路由不需要寫/斜杠跳轉時會帶有*/ }
  return (
    <HashRouter>
      <Routes>
        {/* Main 負責token的判定(重繪和前往) */}
        <Route path='/' element={<Main />} >
          <Route path='/login' element={<Login />} ></Route>
          <Route path='/about' element={<About />} >
            <Route path='' element={<Integrated />} ></Route>
            <Route path='sidebar' element={<Sidebar />} >
              <Route path='' element={<Latent />} ></Route>
              <Route path='particulars' element={<Particulars />} ></Route>
              <Route path='securityCheck' element={<SecurityCheck />} ></Route>
            </Route>
          </Route>
          <Route path='/home' element={<Home />} ></Route>
        </Route>
        {/* 頁面重定向,當跳轉的頁面不存在時,前往404~ */}
        <Route path='*' element={<FourPage />}></Route> 
      </Routes>
    </HashRouter>
  );
}

export default App;
index.js
import React from 'react';
import ReactDOM from 'react-dom/client';
import App from './App';

const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(
  <React.StrictMode>
    <App />
  </React.StrictMode>
);

創建和 App.js 、index.js 同級別的 main.js
// main 組件, 充當 路由子組件的主體 
// 判定 page頁發生改變
// 判定 token 的 狀態變更

import React, { Component, useEffect, useState } from 'react'
import { Outlet, useLocation, useNavigate } from 'react-router-dom';
import storage from './util/storage';
const Main = () => {
    const location = useLocation(); //獲取生命周期鉤子(頁面變化)
    const navigate = useNavigate(); //獲取生命周期鉤子(page跳轉)
    const Token = storage.get('token'); //獲取本地快取:token
    const [newToken, oldToken] = React.useState()

    useEffect(() => { //監聽location變化
        if (!Token) { //不存在
            if (location.pathname === '/') { //地址欄不全
                navigate('/login')
            }
            else if (location.pathname != '/login') {//地址為登錄后
                navigate('/login')
            }
        } else { //存在
            if (location.pathname === '/') { //地址欄不全
                navigate('/login')
            }
        }
        oldToken(Token)
    }, [location,Token]) 
    return <Outlet context={[newToken, oldToken]}></Outlet>
}

export default Main

在src中,創建 util 組態檔夾

配置 storage.js
var storage = {
    set(key, value) { // 添加/編輯  快取
        localStorage.setItem(key, JSON.stringify(value))

    },
    get(key) { // 取出快取資料
        return JSON.parse(localStorage.getItem(key))

    },

    remover(key) { // 移除指定快取
        localStorage.removeItem(key)

    }
}

export default storage;

為page檔案創建

login.js 組件
import React, { Component } from 'react'
import storage from '../../util/storage'
import { useNavigate, useOutletContext } from 'react-router-dom';

const Login = () => {
  const [newToken, oldToken] = useOutletContext();
  const navigate = useNavigate();
  let params = {
      message: '這是跳轉時攜帶的引數',
  }
  const storageToken = () => {
    if (!newToken) {
      storage.set('token', '這是被存盤的token')
      navigate('/about', { state: params });
    } else {
      storage.remover('token')
    }
    oldToken(() => { return storage.get('token')})
  }

  const Btn = () => {
    if (!newToken) {
      return <>
        <button onClick={storageToken}>點擊快取token</button>
      </>
    } else {
      return <>
        <button onClick={storageToken}>點擊清除token</button>
      </>
    }
  }

  return <>
    <h4>這里是登錄前</h4>
    <Btn />
    <br />
    <span>{newToken}</span>
  </>
}
export default Login

about.js 組件
import React from 'react';
import storage from '../../util/storage'
import { Outlet, useNavigate, useLocation, useOutletContext } from 'react-router-dom';

export default function About() {
    const navigate = useNavigate();
    const [newToken, oldToken] = useOutletContext();
    // 需要注意的是 useNavigate() 跳轉只能在無狀態組件中進行 
    let ddd = ['c', 'n']

    const [count, setCount] = React.useState(ddd); // 資料共享
    // 需要注意的是,它只能傳入兩組欄位,一組為原始資料,一組變更資料,用作對比時,每次資料變動
    // 頁面隨之更新  傳入的資料型別由自己決定

    const state = useLocation() //接收引數
    console.log('state', state)

    //  navigate('', {}) // 前往默認頁
    //  navigate('/home', {}) // 前往其他頁
    //  navigate('檔案名/子檔案', {}) //前往子級
    //  navigate('檔案名', {replace: true}) //前往當前路由其他同級頁  replace: true 重定向
    return (
        <>
            <h4>About</h4>
            <button onClick={() => {
                navigate('test', { state: ddd });
                // state 傳參不限制傳參型別
            }}>點擊Test頁</button>

            <button onClick={() => {
                storage.remover('token'); 
                setTimeout(() => {
                    oldToken(storage.get('token'))
                }, 500)
            }} >在頁內清token</button>
            <Outlet context={[count, setCount]} />
            <div>{newToken}</div>
        </>
    )
}

轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/556435.html

標籤:其他

上一篇:vane 一個適用于前端打工人的全堆疊框架,nodejs+vue3+typescript

下一篇:返回列表

標籤雲
其他(161948) Python(38266) JavaScript(25519) Java(18286) C(15238) 區塊鏈(8275) C#(7972) AI(7469) 爪哇(7425) MySQL(7278) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5876) 数组(5741) R(5409) Linux(5347) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4609) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2438) ASP.NET(2404) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) .NET技术(1985) HtmlCss(1982) 功能(1967) Web開發(1951) C++(1942) python-3.x(1918) 弹簧靴(1913) xml(1889) PostgreSQL(1881) .NETCore(1863) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • IEEE1588PTP在數字化變電站時鐘同步方面的應用

    IEEE1588ptp在數字化變電站時鐘同步方面的應用 京準電子科技官微——ahjzsz 一、電力系統時間同步基本概況 隨著對IEC 61850標準研究的不斷深入,國內外學者提出基于IEC61850通信標準體系建設數字化變電站的發展思路。數字化變電站與常規變電站的顯著區別在于程序層傳統的電流/電壓互 ......

    uj5u.com 2020-09-10 03:51:52 more
  • HTTP request smuggling CL.TE

    CL.TE 簡介 前端通過Content-Length處理請求,通過反向代理或者負載均衡將請求轉發到后端,后端Transfer-Encoding優先級較高,以TE處理請求造成安全問題。 檢測 發送如下資料包 POST / HTTP/1.1 Host: ac391f7e1e9af821806e890 ......

    uj5u.com 2020-09-10 03:52:11 more
  • 網路滲透資料大全單——漏洞庫篇

    網路滲透資料大全單——漏洞庫篇漏洞庫 NVD ——美國國家漏洞庫 →http://nvd.nist.gov/。 CERT ——美國國家應急回應中心 →https://www.us-cert.gov/ OSVDB ——開源漏洞庫 →http://osvdb.org Bugtraq ——賽門鐵克 →ht ......

    uj5u.com 2020-09-10 03:52:15 more
  • 京準講述NTP時鐘服務器應用及原理

    京準講述NTP時鐘服務器應用及原理京準講述NTP時鐘服務器應用及原理 安徽京準電子科技官微——ahjzsz 北斗授時原理 授時是指接識訓通過某種方式獲得本地時間與北斗標準時間的鐘差,然后調整本地時鐘使時差控制在一定的精度范圍內。 衛星導航系統通常由三部分組成:導航授時衛星、地面檢測校正維護系統和用戶 ......

    uj5u.com 2020-09-10 03:52:25 more
  • 利用北斗衛星系統設計NTP網路時間服務器

    利用北斗衛星系統設計NTP網路時間服務器 利用北斗衛星系統設計NTP網路時間服務器 安徽京準電子科技官微——ahjzsz 概述 NTP網路時間服務器是一款支持NTP和SNTP網路時間同步協議,高精度、大容量、高品質的高科技時鐘產品。 NTP網路時間服務器設備采用冗余架構設計,高精度時鐘直接來源于北斗 ......

    uj5u.com 2020-09-10 03:52:35 more
  • 詳細解讀電力系統各種對時方式

    詳細解讀電力系統各種對時方式 詳細解讀電力系統各種對時方式 安徽京準電子科技官微——ahjzsz,更多資料請添加VX 衛星同步時鐘是我京準公司開發研制的應用衛星授時時技術的標準時間顯示和發送的裝置,該裝置以M國全球定位系統(GLOBAL POSITIONING SYSTEM,縮寫為GPS)或者我國北 ......

    uj5u.com 2020-09-10 03:52:45 more
  • 如何保證外包團隊接入企業內網安全

    不管企業規模的大小,只要企業想省錢,那么企業的某些服務就一定會采用外包的形式,然而看似美好又經濟的策略,其實也有不好的一面。下面我通過安全的角度來聊聊使用外包團的安全隱患問題。 先看看什么服務會使用外包的,最常見的就是話務/客服這種需要大量重復性、無技術性的服務,或者是一些銷售外包、特殊的職能外包等 ......

    uj5u.com 2020-09-10 03:52:57 more
  • PHP漏洞之【整型數字型SQL注入】

    0x01 什么是SQL注入 SQL是一種注入攻擊,通過前端帶入后端資料庫進行惡意的SQL陳述句查詢。 0x02 SQL整型注入原理 SQL注入一般發生在動態網站URL地址里,當然也會發生在其它地發,如登錄框等等也會存在注入,只要是和資料庫打交道的地方都有可能存在。 如這里http://192.168. ......

    uj5u.com 2020-09-10 03:55:40 more
  • [GXYCTF2019]禁止套娃

    git泄露獲取原始碼 使用GET傳參,引數為exp 經過三層過濾執行 第一層過濾偽協議,第二層過濾帶引數的函式,第三層過濾一些函式 preg_replace('/[a-z,_]+\((?R)?\)/', NULL, $_GET['exp'] (?R)參考當前正則運算式,相當于匹配函式里的引數 因此傳遞 ......

    uj5u.com 2020-09-10 03:56:07 more
  • 等保2.0實施流程

    流程 結論 ......

    uj5u.com 2020-09-10 03:56:16 more
最新发布
  • React學習時,outlet配置(token判定,頁面path監聽)

    盡管寫過 outlet 路由的配置。 考慮到 token 判定和 路由頁 變更,我不了解v6是不是有更詳解的做法。 決定調一下配置,期望 在任何頁面異步更新時,token 都可以在跳轉前 被檢測到,防止無 token 跳轉發生。 補上404頁面( 地址欄 頁面不存在時,展示404頁面 ) ![](h ......

    uj5u.com 2023-07-01 08:42:58 more
  • vane 一個適用于前端打工人的全堆疊框架,nodejs+vue3+typescript

    # vane 寫這個的初衷是因為每次用node寫介面的時候總是需要一些寫大一堆的東西, 也有些人把很多介面都放在一個js檔案內, 看起來很是雜亂, 后來用到nuxt寫的時候, 感覺用檔案名來命名介面路徑很是方便, 無論是query引數還是params引數,都可以通過檔案名來命名, 也可以通過檔案夾層 ......

    uj5u.com 2023-07-01 08:42:43 more
  • Prisma 避坑指南!

    * 環境變數問題 ```typescript datasource db { provider = "mysql" url = env("DATABASE_URL") } ``` 1. `npx prisma db push` 默認取 .env 組態檔,那多環境怎么處理? 2. 增加 `.env. ......

    uj5u.com 2023-07-01 08:42:38 more
  • 記錄--讓整個網站界面無滾動條

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 界面無滾動條 滾動條的優化也有很多種,比如隨便再網上搜索美化瀏覽器滾動條樣式,就會出現些用css去美化滾動條的方案。 那種更好呢? 沒有更好只有更合適 像默認的滾動條的話,他能讓你方便摁著往下滑動(他比較寬)特別省勁,不用擔心美化過后變細 ......

    uj5u.com 2023-07-01 08:42:11 more
  • 如何實作巡檢報告?

    # 什么是巡檢報告 巡檢報告是指對某一個系統或設備進行全面檢查,并把檢查結果及建議整理成報告的程序。 巡檢報告通常用于評估系統或設備的運行狀況與性能,以發現問題、優化系統、提高效率、降低故障率等方面提供參考。 ![file](https://img2023.cnblogs.com/other/233 ......

    uj5u.com 2023-07-01 08:41:36 more
  • HTML網頁內容適配——標題欄

    前言 現在很多網頁用的都是固定標題欄,就像這樣: 很多網站為了兼容小視窗還會做個JS適配: 但是如果視窗比這還小的話... 那就只剩下一部分了。 由于設定position:fixed后元素不會隨著滾動條滾動,所以超出頁面邊緣的部分將永遠看不見,除非增大視窗或縮小顯示比例。 很多設計師忘記考慮這一點了 ......

    uj5u.com 2023-07-01 08:40:26 more
  • 1.1 Metasploit 工具簡介

    Metasploit 簡稱(MSF)是一款流行的開源滲透測驗框架,由`Rapid7`公司開發,可以幫助安全和IT專業人士識別安全性問題,驗證漏洞的緩解措施,并管理專家驅動的安全性進行評估,提供真正的安全風險情報。并且該框架還提供了一系列攻擊模塊和`Payload`工具,可用于漏洞利用、及漏洞攻擊。同... ......

    uj5u.com 2023-07-01 08:39:46 more
  • 1.1 Metasploit 工具簡介

    Metasploit 簡稱(MSF)是一款流行的開源滲透測驗框架,由`Rapid7`公司開發,可以幫助安全和IT專業人士識別安全性問題,驗證漏洞的緩解措施,并管理專家驅動的安全性進行評估,提供真正的安全風險情報。并且該框架還提供了一系列攻擊模塊和`Payload`工具,可用于漏洞利用、及漏洞攻擊。同... ......

    uj5u.com 2023-07-01 08:38:27 more
  • Vue3從入門到精通(三)

    vue3插槽Slots 在 Vue3 中,插槽(Slots)的使用方式與 Vue2 中基本相同,但有一些細微的差異。以下是在 Vue3 中使用插槽的示例: // ChildComponent.vue <template> <div> <h2>Child Component</h2> <slot></ ......

    uj5u.com 2023-06-30 09:07:11 more
  • 記錄--寫一個高德地圖巡航功能的小DEMO

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 風格設定 加載地圖 使用AMapLoader.load加載地圖,從 控制臺 申請一個屬于自己的key import AMapLoader from '@amap/amap-jsapi-loader'; ... const AMap = a ......

    uj5u.com 2023-06-30 08:29:46 more