react搭建后臺管理系統(tǒng)(上篇)

創(chuàng)建項(xiàng)目

npm init vite

復(fù)制依賴

dependencies: {
  "react": "^18.2.0",
  "react-dom": "^18.2.0",
  "react-redux": "^7.2.8",
  "react-router-dom": "^6.3.0",
  "redux": "^4.1.2"
}

樣式初始化

可以安裝css庫來進(jìn)行樣式的初始化,有reset-css、normalize.css,這里安裝reset-css

npm i reset-css
// 在main.tsx中引入
// 初始化樣式放在最前面
import 'reset-css'
// UI組件庫的樣式
// 自定義組件自身的樣式
import App from './App'

路徑別名配置

在vite.config.ts中配置@符號

import path from 'path'
export default defineConfig({
  plugins: [react()],
  resolve: {
    alias: {
      "@": path.resolve(__dirname, './src')
    }
  }
})

path是node的內(nèi)置模塊爱态,安裝好node就安裝好了path,如果此時(shí)path爆紅骏融,是因?yàn)槿鄙賢s的一些聲明箭跳,所以安裝ts的這些聲明即可

npm i -D @types/node

安裝成功后就不爆紅了析苫,如果import 后面的path爆紅就把引入改成

import * as path from 'path'

這個(gè)和vite的版本有關(guān)系

路徑別名提示

在tsconfig.json文件中配置如下信息

"compilerOptions": {
  ...
  "baseUrl": "./",
    "paths": {
      "@/*": [
        "src/*"
      ]
    }
}

react 樣式模塊化

樣式模塊化的方法有很多這里記錄一下module.css的方法

  • 首先需要將樣式文件后綴修改為 .module.css 我項(xiàng)目中使用的是scss因此樣式文件命名為xxx.module.scss
  • 在組件中引入相應(yīng)的樣式文件
import styles from './comp1.module.scss' // 此時(shí)的樣式文件好像js中的對象
function Comp1() {
  return (
    <div className={styles.box}>
      <p>我是comp1組件</p>
    </div>
  )
}

export default Comp1

配置vite-plugin-style-import按需引入樣式

npm i vite-plugin-style-import@1.4.1

在vite.config.ts中的配置

import { defineConfig } from 'vite'
import react from '@vitejs/plugin-react'
import * as path from 'path'
import styleImport, { AntdResolve } from 'vite-plugin-style-import'
export default defineConfig({
  plugins: [
    react(),
    styleImport({
      resolves:[
        AntdResolve()
      ]
    })
  ],
  resolve: {
    alias: {
      "@": path.resolve(__dirname, './src')
    }
  }
})

因?yàn)閍ntd默認(rèn)引入的是less文件兜叨,因此還需要安裝一下less

npm i less@2.7.1

React 中的路由

react18走之前的寫法

// src\router\index.tsx
import App  from "@/App";
import Home from "@/views/Home";
import About from "@/views/About";
import { BrowserRouter, Routes, Route, Navigate } from "react-router-dom";

// 兩種路由模式的組件: BrowserRouter{History 模式} 穿扳、HashRouter{hash模式}
const baseRouter = () => (
  <BrowserRouter>
    <Routes>
      <Route path="/" element={<App/>}>
         {/*Navigate 重定向  */}
        <Route path="/" element={<Navigate to="/home"/>}></Route>
        <Route path="/home" element={<Home/>}></Route>
        <Route path="/about" element={<About/>}></Route>
      </Route>
    </Routes>
  </BrowserRouter>
)

export default baseRouter
// src\main.tsx
import Router from './router'
ReactDOM.createRoot(document.getElementById('root') as HTMLElement).render(
  <React.StrictMode>
    <Router />
  </React.StrictMode>,
)
// src\App.tsx
import { Outlet, Link } from 'react-router-dom'
// Outlet 是占位符類似于vue的router-view
function App() {
  return (
    <div className="App">
      {/* Link 類似于vue的route-link */}
      <Link to="/home">Home</Link>|
      <Link to="/about">About</Link>
      <Outlet></Outlet>
    </div>
  )
}

export default App

React18 路由新寫法

路由新寫法支持路由對象的形式編寫路由

// src\router\index.tsx
import Home from "@/views/Home";
import About from "@/views/About";
import { Navigate } from 'react-router-dom'
// Navigate 路由重定向
const routes = [
  {
    path: '/',
    element: <Navigate to="/home"/>
  },
  {
    path: '/home',
    element: <Home />
  },
  {
    path: '/about',
    element: <About />
  }
]

export default routes
// src\main.tsx
import React from 'react'
import ReactDOM from 'react-dom/client'
import 'reset-css'
import App from './App'
import { BrowserRouter } from 'react-router-dom'
import '@/assets/style/global.scss'
ReactDOM.createRoot(document.getElementById('root') as HTMLElement).render(
  <React.StrictMode>
    <BrowserRouter>
      <App/>
    </BrowserRouter>
  </React.StrictMode>,
)

// src\App.tsx
import { useRoutes, Link } from 'react-router-dom'
import routes from './router'
function App() {
  const outlet = useRoutes(routes) // hook 形式的頁面占位符
  return (
    <div className="App">
      {/* Link 類似于vue的route-link */}
      <Link to="/home">Home</Link>|
      <Link to="/about">About</Link>
      { outlet }
    </div>
  )
}

export default App

路由懶加載

路由懶加載需要借助react的lazy 方法并且需要搭配react的Suspense組件

import React, { lazy } from 'react'
import { Navigate } from 'react-router-dom'
// 因?yàn)镠ome組件首頁需要顯示因此無需懶加載
import Home from "@/views/Home";
// 組件懶加載
const About = lazy(() => import("@/views/About"))
// 懶加載的組件需要用Suspense包裹
const withLoadingComponent = (comp:JSX.Element) => (
  <React.Suspense fallback={<div>Loading...</div>}>
    { comp }
  </React.Suspense>
)
const routes = [
  {
    path: '/',
    element: <Navigate to="/home"/>
  },
  {
    path: '/home',
    element: <Home />
  },
  {
    path: '/about',
    element: withLoadingComponent(<About />)
  }
]

export default routes
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市国旷,隨后出現(xiàn)的幾起案子矛物,更是在濱河造成了極大的恐慌,老刑警劉巖议街,帶你破解...
    沈念sama閱讀 218,284評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件泽谨,死亡現(xiàn)場離奇詭異,居然都是意外死亡特漩,警方通過查閱死者的電腦和手機(jī)吧雹,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來涂身,“玉大人雄卷,你說我怎么就攤上這事「蚴郏” “怎么了丁鹉?”我有些...
    開封第一講書人閱讀 164,614評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長悴能。 經(jīng)常有香客問我揣钦,道長,這世上最難降的妖魔是什么漠酿? 我笑而不...
    開封第一講書人閱讀 58,671評論 1 293
  • 正文 為了忘掉前任冯凹,我火速辦了婚禮,結(jié)果婚禮上炒嘲,老公的妹妹穿的比我還像新娘宇姚。我一直安慰自己,他們只是感情好夫凸,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,699評論 6 392
  • 文/花漫 我一把揭開白布浑劳。 她就那樣靜靜地躺著,像睡著了一般夭拌。 火紅的嫁衣襯著肌膚如雪魔熏。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,562評論 1 305
  • 那天啼止,我揣著相機(jī)與錄音道逗,去河邊找鬼。 笑死献烦,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的卖词。 我是一名探鬼主播巩那,決...
    沈念sama閱讀 40,309評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼吏夯,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了即横?” 一聲冷哼從身側(cè)響起噪生,我...
    開封第一講書人閱讀 39,223評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎东囚,沒想到半個(gè)月后跺嗽,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,668評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡页藻,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,859評論 3 336
  • 正文 我和宋清朗相戀三年桨嫁,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片份帐。...
    茶點(diǎn)故事閱讀 39,981評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡璃吧,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出废境,到底是詐尸還是另有隱情畜挨,我是刑警寧澤,帶...
    沈念sama閱讀 35,705評論 5 347
  • 正文 年R本政府宣布噩凹,位于F島的核電站巴元,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏驮宴。R本人自食惡果不足惜逮刨,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,310評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望幻赚。 院中可真熱鬧禀忆,春花似錦、人聲如沸落恼。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽佳谦。三九已至戴涝,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間钻蔑,已是汗流浹背啥刻。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留咪笑,地道東北人可帽。 一個(gè)月前我還...
    沈念sama閱讀 48,146評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像窗怒,于是被迫代替她去往敵國和親映跟。 傳聞我的和親對象是個(gè)殘疾皇子蓄拣,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,933評論 2 355

推薦閱讀更多精彩內(nèi)容