精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

一個(gè)簡(jiǎn)潔、強(qiáng)大、可擴(kuò)展的前端項(xiàng)目架構(gòu)是什么樣的?

開(kāi)發(fā) 前端
本文要介紹一個(gè)12.7k的開(kāi)源項(xiàng)目,這個(gè)項(xiàng)目為構(gòu)建「簡(jiǎn)潔、強(qiáng)大、可擴(kuò)展的前端項(xiàng)目架構(gòu)」的方方面面給出了建議。

大家好,我卡頌。

React技術(shù)棧的一大優(yōu)勢(shì)在于 —— 社區(qū)繁榮,你業(yè)務(wù)中需要實(shí)現(xiàn)的功能基本都能找到對(duì)應(yīng)的開(kāi)源庫(kù)。

但繁榮也有不好的一面 —— 要實(shí)現(xiàn)同樣的功能,有太多選擇,到底選哪個(gè)?

本文要介紹一個(gè)12.7k的開(kāi)源項(xiàng)目 —— Bulletproof React[1]。

這個(gè)項(xiàng)目為構(gòu)建「簡(jiǎn)潔、強(qiáng)大、可擴(kuò)展的前端項(xiàng)目架構(gòu)」的方方面面給出了建議。

Bulletproof React是什么

Bulletproof React與我們常見(jiàn)的腳手架(比如CRA)不同,后者的作用是「根據(jù)模版創(chuàng)建一個(gè)新項(xiàng)目」。

而前者包含一個(gè)完整的React全棧論壇項(xiàng)目:

圖片用戶(hù)登錄頁(yè)面

作者通過(guò)這個(gè)項(xiàng)目舉例,展示了與「項(xiàng)目架構(gòu)」相關(guān)的13個(gè)方面的內(nèi)容,比如:

  • 文件目錄該如何組織。
  • 工程化配置有什么推薦。
  • 寫(xiě)業(yè)務(wù)組件時(shí)該怎么規(guī)范。
  • 怎么做狀態(tài)管理。
  • API層如何設(shè)計(jì)。
  • 等等......。

圖片圖片

限于篇幅有限,本文介紹其中部分觀點(diǎn)。

不知道這些觀點(diǎn)你是否認(rèn)同呢?

文件目錄如何組織

項(xiàng)目推薦如下目錄形式:

src
|
+-- assets # 靜態(tài)資源
|
+-- components # 公共組件
|
+-- config # 全局配置
|
+-- features # 特性
|
+-- hooks # 公用hooks
|
+-- lib # 二次導(dǎo)出的第三方庫(kù)
|
+-- providers # 應(yīng)用中所有providers
|
+-- routes # 路由配置
|
+-- stores # 全局狀態(tài)stores
|
+-- test # 測(cè)試工具、mock服務(wù)器
|
+-- types # 全局類(lèi)型文件
|
+-- utils # 通用工具函數(shù)

其中,features目錄與components目錄的區(qū)別在于:

components存放全局公用的組件,而features存放「業(yè)務(wù)相關(guān)特性」。

比如我要開(kāi)發(fā)「評(píng)論」模塊,「評(píng)論」作為一個(gè)特性,與他相關(guān)的所有內(nèi)容都存在于features/comments目錄下。

「評(píng)論」模塊中需要輸入框,輸入框這個(gè)通用組件來(lái)自于components目錄。

所有「特性相關(guān)」的內(nèi)容都會(huì)收斂到features目錄下,具體包括:

src/features/xxx-feature
|
+-- api # 與特性相關(guān)的請(qǐng)求
|
+-- assets # 與特性相關(guān)的靜態(tài)資源
|
+-- components # 與特性相關(guān)的組件
|
+-- hooks # 與特性相關(guān)的hooks
|
+-- routes # 與特性相關(guān)的路由
|
+-- stores # 與特性相關(guān)的狀態(tài)stores
|
+-- types # 與特性相關(guān)的類(lèi)型申明
|
+-- utils # 與特性相關(guān)的工具函數(shù)
|
+-- index.ts # 入口

特性導(dǎo)出的所有內(nèi)容只能通過(guò)統(tǒng)一的入口調(diào)用,比如:

import { CommentBar } from "@/features/comments"

而不是:

import { CommentBar } from "@/features/comments/components/CommentBar

這可以通過(guò)配置ESLint實(shí)現(xiàn):

{
rules: {
'no-restricted-imports': [
'error',
{
patterns: ['@/features/*/*'],
},
],
// ...其他配置
}
}

相比于將「特性相關(guān)的內(nèi)容」都以「扁平的形式」存放在全局目錄下(比如將特性的hooks存放在全局hooks目錄),以features目錄作為「相關(guān)代碼的集合」能夠有效防止項(xiàng)目體積增大后代碼組織混亂的情況。

怎么做狀態(tài)管理

項(xiàng)目中并不是所有狀態(tài)都需要保存在「中心化的store」中,需要根據(jù)狀態(tài)類(lèi)型區(qū)別對(duì)待。

組件狀態(tài)

對(duì)于組件的局部狀態(tài),如果只有組件自身以及他的子孫組件需要這部分狀態(tài),那么可以用useState或useReducer保存他們。

應(yīng)用狀態(tài)

與應(yīng)用交互相關(guān)的狀態(tài),比如「打開(kāi)彈窗」、「通知」、「改變黑夜模式」等,應(yīng)該遵循「將狀態(tài)盡可能靠近使用他的組件」的原則,不要什么狀態(tài)都定義為「全局狀態(tài)」。

以Bulletproof React中的示例項(xiàng)目舉例,首先定義「通知相關(guān)的狀態(tài)」:

// bulletproof-react/src/stores/notifications.ts
export const useNotificationStore = create<NotificationsStore>((set) => ({
notifications: [],
addNotification: (notification) =>
set((state) => ({
notifications: [...state.notifications, { id: nanoid(), ...notification }],
})),
dismissNotification: (id) =>
set((state) => ({
notifications: state.notifications.filter((notification) => notification.id !== id),
})),
}));

再在任何使用「通知相關(guān)的狀態(tài)」的地方引用useNotificationStore,比如:

// bulletproof-react/src/components/Notifications/Notifications.tsx
import { useNotificationStore } from '@/stores/notifications';
import { Notification } from './Notification';
export const Notifications = () => {
const { notifications, dismissNotification } = useNotificationStore();
return (
<div
>
{notifications.map((notification) => (
<Notification
key={notification.id}
notification={notification}
onDismiss={dismissNotification}
/>
))}
</div>
);
};

這里使用的狀態(tài)管理工具是zustand,除此之外還有很多可選方案:

  • context? +hooks
  • redux? +redux toolkit
  • mobx
  • constate
  • jotai
  • recoil
  • xstate

這些方案各有特點(diǎn),但他們都是為了處理「應(yīng)用狀態(tài)」。

服務(wù)端緩存狀態(tài)

對(duì)于從服務(wù)端請(qǐng)求而來(lái),緩存在前端的數(shù)據(jù),雖然可以用上述處理「應(yīng)用狀態(tài)」的工具解決,但「服務(wù)端緩存狀態(tài)」相比于「應(yīng)用狀態(tài)」,還涉及到「緩存失效」、「序列化數(shù)據(jù)」等問(wèn)題。

所以最好用專(zhuān)門(mén)的工具處理,比如:

  • react-query - REST? +GraphQL
  • swr - REST? +GraphQL
  • apollo client? -GraphQL
  • urql? -GraphQl

表單狀態(tài)

表單數(shù)據(jù)需要區(qū)分「受控」與「非受控」,表單本身還有很多邏輯需要處理(比如「表單校驗(yàn)」),所以也推薦用專(zhuān)門(mén)的庫(kù)處理這部分狀態(tài),比如:

  • React Hook Form
  • Formik
  • React Final Form

URL狀態(tài)

URL狀態(tài)包括:

  • url params (/app/${dynamicParam})
  • query params (/app?dynamicParam=1)

這部分狀態(tài)通常是路由庫(kù)處理,比如react-router-dom。

總結(jié)

本文節(jié)選了部分Bulletproof React中推薦的方案,有沒(méi)有讓你認(rèn)可的觀點(diǎn)呢?

歡迎在評(píng)論區(qū)交流項(xiàng)目架構(gòu)中的最佳實(shí)踐。

參考資料

[1]Bulletproof React:https://github.com/alan2207/bulletproof-react。

責(zé)任編輯:姜華 來(lái)源: 魔術(shù)師卡頌
相關(guān)推薦

2020-04-24 10:02:44

組件Vue組件庫(kù)

2023-12-04 06:55:16

2020-09-21 08:01:35

Git操作系統(tǒng)Linux

2022-02-15 10:45:50

軟件汽車(chē)開(kāi)發(fā)

2018-01-05 08:54:09

加固型數(shù)據(jù)中心業(yè)務(wù)

2022-10-30 15:03:25

人工智能倉(cāng)庫(kù)管理機(jī)器人

2014-02-17 17:18:00

程序員

2017-07-27 16:25:54

云管理公共云合并

2017-12-17 16:53:27

云計(jì)算亞馬遜云端

2013-01-31 11:51:37

開(kāi)源KVM

2013-02-27 10:53:16

開(kāi)源KVM

2016-12-07 18:10:08

邊緣計(jì)算

2022-06-17 08:30:00

元宇宙Meta架構(gòu)

2024-11-20 13:18:21

2015-04-08 10:40:09

2019-01-11 10:39:24

軟件架構(gòu)虛擬空間機(jī)器人

2024-06-27 08:55:41

2020-07-15 07:57:17

代碼Vue開(kāi)發(fā)

2020-07-14 14:50:44

Vue代碼前端

2020-12-03 06:34:34

分支策略SIT
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

久久久影院一区二区三区| 九九热最新视频//这里只有精品| 久热免费在线观看| av播放在线| 国产精品系列在线播放| 欧美日韩高清区| 成年人网站免费看| 精品亚洲a∨| 亚洲天堂av一区| 激情小说综合网| 伊人网av在线| 国产精品hd| 亚洲日本中文字幕免费在线不卡| 亚洲高清免费在线观看| 国产丝袜在线播放| 久久精品一区蜜桃臀影院| 95av在线视频| 精品一区二区无码| 欧美日韩影院| 中文字幕最新精品| 国产 xxxx| 日本一区二区中文字幕| 亚洲va中文字幕| 综合操久久久| 嫩草研究院在线| 国产成人欧美日韩在线电影| 久久久久五月天| 蜜桃av免费在线观看| 欧美人妖在线观看| 678五月天丁香亚洲综合网| 日本www在线视频| av免费看在线| 国产精品久久久久三级| 久久国产精品久久精品国产| 精品久久久久中文慕人妻 | 国产一区二区三区在线看| 色噜噜狠狠一区二区三区狼国成人| 中文字幕色婷婷在线视频| 悠悠色在线精品| 三年中文高清在线观看第6集| 你懂得在线网址| 91免费观看视频在线| 亚洲中国色老太| 国产精品久久久久久久成人午夜| 久久久久久穴| 5278欧美一区二区三区| 国产一级一级片| 午夜精品久久久久99热蜜桃导演| 日韩一区二区三区xxxx| 在线观看国产精品一区| 红桃视频在线观看一区二区| 日韩av在线网址| 中国免费黄色片| 日韩在线精品强乱中文字幕| 6080国产精品一区二区| 日韩一区二区三区久久| 农村妇女一区二区| 欧美日韩在线电影| 中文字幕第100页| 国产极品嫩模在线观看91精品| 欧日韩精品视频| 能在线观看的av网站| 欧美momandson| 在线看国产一区二区| 国产91在线视频观看| 日韩欧美精品一区二区三区| 精品国产成人av| 大陆极品少妇内射aaaaa| 日韩伦理在线一区| 在线亚洲高清视频| 亚洲精品www.| 国产日韩欧美中文在线| 日韩精品最新网址| 艳妇乳肉豪妇荡乳xxx| 精品国产午夜肉伦伦影院| 亚洲精品720p| 91成人在线免费视频| 欧美日韩一区二区综合| 中文字幕在线亚洲| 青娱乐av在线| 亚洲少妇在线| 国产黑人绿帽在线第一区| 中文字幕乱码人妻二区三区| 国产原创一区二区| 国产成人av一区二区三区| 手机看片国产1024| 久久久精品一品道一区| 在线综合视频网站| 国产亚av手机在线观看| 欧美性xxxxx极品娇小| www.天天射.com| 国产精品成人**免费视频| 精品国产一区二区在线观看| 韩国无码一区二区三区精品| 日韩欧美网站| 久久久久久亚洲精品| 男人天堂2024| 国产精品综合网| 久久久国产精品一区二区三区| 成年女人的天堂在线| 一区二区在线免费观看| 精品www久久久久奶水| 国产精品3区| 亚洲黄页视频免费观看| 又嫩又硬又黄又爽的视频| 国产精品成人一区二区网站软件| 日韩av电影在线网| 99国产在线播放| 久久嫩草精品久久久精品| 中文字幕日韩一区二区三区| 白浆在线视频| 欧美一区二区网站| 亚洲一区视频在线播放| 欧美精品一级| 国产精品夜色7777狼人| 四虎精品在永久在线观看 | 国产乱人伦精品一区二区在线观看 | 国产精品99久久久久久大便| 欧美日韩在线观看首页| 777午夜精品免费视频| 黑丝av在线播放| 亚洲综合色网| 国产欧美精品在线| 男女视频在线观看| 亚洲自拍偷拍九九九| 午夜激情av在线| 欧美**vk| 136fldh精品导航福利| 国产精品久久久久久久一区二区| 久久久久国产精品厨房| 久激情内射婷内射蜜桃| 日韩三级网址| 久久国产一区二区三区| 无码人妻aⅴ一区二区三区有奶水| 国产成人精品免费| 亚洲成人在线视频网站| 欧美成人性网| 亚洲精品美女在线观看| 麻豆国产尤物av尤物在线观看| 老司机精品视频一区二区三区| 欧美日韩一区二区三| 8x8ⅹ拨牐拨牐拨牐在线观看| 日韩一区国产二区欧美三区| 国产大屁股喷水视频在线观看| 另类亚洲自拍| 欧美精品一区三区在线观看| 黄色aa久久| 精品电影一区二区| 欧美日韩国产精品综合| 国产一区二区久久| 国产高潮呻吟久久久| 永久免费观看精品视频| 日韩一区视频在线| 亚洲天堂免费av| 国产精品久久久久桃色tv| 亚洲天堂国产视频| 91九色精品国产一区二区| 国产精品欧美激情| 91美女视频在线| 欧美人牲a欧美精品| 亚洲少妇xxx| 国产一区二区三区日韩| 亚洲自拍偷拍一区二区三区| 国产亚洲高清在线观看| 欧美精品生活片| 好男人在线视频www| 精品欧美激情精品一区| 波多野吉衣中文字幕| 日韩精品高清不卡| 色女人综合av| 精品入口麻豆88视频| 欧美大片欧美激情性色a∨久久| 国产xxxx孕妇| 性欧美大战久久久久久久久| 在线免费观看黄色小视频| 久热精品视频| 亚洲一区二区在线观| 精品一区二区三区视频在线播放| 欧美福利视频网站| 午夜视频1000| 精品视频一区二区不卡| 婷婷伊人五月天| 成人看片黄a免费看在线| 黄色片视频在线免费观看| 精品国产乱码| 91入口在线观看| 厕沟全景美女厕沟精品| 中文字幕亚洲图片| 精品国产无码一区二区三区| 亚洲18女电影在线观看| 久久视频精品在线观看| 国产精品亚洲午夜一区二区三区| 成人毛片视频网站| 中国女人真人一级毛片| 欧美韩国一区| 精品一区国产| 日本午夜精品久久久久| 久久久人成影片一区二区三区| 水莓100在线视频| 欧美喷水一区二区| 国产一级特黄a高潮片| 国产欧美日韩中文久久| 一区二区三区人妻| 久久久久国产精品一区二区| 天天干天天色天天爽| 欧美调教在线| 成人www视频在线观看| 91jq激情在线观看| 久久精品99久久香蕉国产色戒| 天堂网在线播放| 欧美一区二区三区在线电影| 久久99国产综合精品免费| 日韩久久一区二区| 女人又爽又黄免费女仆| 国产成人免费在线观看不卡| 日本在线观看免费视频| 亚洲美女色禁图| 成年人三级视频| 日韩精品二区| 免费久久99精品国产自| 日韩国产在线不卡视频| 国产精品丝袜视频| 黑人巨大精品| 久久久视频免费观看| 免费在线看黄网站| 亚洲日本欧美中文幕| 午夜一区在线观看| 欧美成人女星排名| 91资源在线视频| 精品视频1区2区| 成人一二三四区| 色综合久久天天综合网| 久久久久久久久久久久久久免费看 | 国产精品久久久久久久一区探花 | 久久视频在线| 欧美视频小说| 妖精视频一区二区三区免费观看| 不卡视频一区二区三区| 只有精品亚洲| 国产一区玩具在线观看| 主播大秀视频在线观看一区二区| 欧美一区二区视频97| h片在线观看视频免费免费| 久久视频在线播放| 五月婷婷在线视频| 在线观看日韩欧美| 国产一二三在线观看| 亚洲夜晚福利在线观看| 四虎影院在线播放| 亚洲精品一区二区三区婷婷月| 神马午夜电影一区二区三区在线观看| 欧美成人福利视频| www.好吊色| 欧美成人精品3d动漫h| 亚洲av无码乱码国产精品久久| 91精品久久久久久久久99蜜臂| 国产毛片在线视频| 91精品在线一区二区| 99久久精品国产一区二区成人| 欧美一区二区三区免费在线看| 精品国产av一区二区| 日韩精品一区二区三区在线| 国精产品一品二品国精品69xx | 国产视频第一区| 亚洲四色影视在线观看| 成人高清免费观看mv| 最新中文字幕亚洲| dj大片免费在线观看| 欧美国产中文字幕| www视频在线观看| 欧美一级成年大片在线观看| 电影亚洲精品噜噜在线观看| 国产精品黄视频| 国产精品久久久久久久久久辛辛 | 亚洲男同性恋视频| 久久精品99久久久久久| 精品国产精品自拍| 高潮毛片又色又爽免费 | 成人激情免费视频| youjizz.com亚洲| 激情视频一区| 欧美激情国产精品日韩| 免费观看一级特黄欧美大片| 91性高潮久久久久久久| a级精品国产片在线观看| 日本xxxxxxxxx18| 亚洲视频香蕉人妖| 日韩美女视频网站| 欧美日韩一区二区三区四区 | 国产精品18久久久久久vr| 国产一级伦理片| 中文字幕在线视频一区| 国产性生活网站| 欧美在线观看视频在线| 亚洲av无码片一区二区三区| 亚洲欧美激情四射在线日| 久久亚洲天堂| 57pao成人永久免费视频| av国产精品| 狠狠干一区二区| 久久精品国内一区二区三区水蜜桃 | 超碰caoprom| 国产精品久久久久影视| 91美女免费看| 欧美一二三区在线观看| 邻家有女韩剧在线观看国语| 精品中文字幕在线| 韩国成人在线| 精品国产综合区久久久久久| 五月开心六月丁香综合色啪 | 精品一区二区三区免费毛片爱| 国产人妻黑人一区二区三区| 国产精品久线在线观看| 国产成人无码一区二区三区在线 | 91sa在线看| 日韩三级精品| 亚洲精品影院| 日韩精品成人一区二区在线| 亚洲精品第二页| 亚洲免费av高清| 在线观看视频中文字幕| 亚洲美女精品久久| 国产美女高潮在线观看| 高清国语自产拍免费一区二区三区| 日韩av免费大片| 久久久久久久久久久免费视频| 国产福利一区二区三区在线视频| 五月婷婷欧美激情| 色呦呦一区二区三区| 日韩中文字幕免费在线观看| 久久人人爽人人爽人人片亚洲| 91av一区| 日韩激情视频| 丝袜美腿亚洲一区二区图片| 国产一级二级在线观看| 亚洲综合色视频| 精品国产99久久久久久宅男i| 综合国产在线视频| 久久精品国产福利| 亚洲精品中文字幕在线 | 国产91露脸中文字幕在线| 激情小说亚洲图片| www插插插无码视频网站| 粉嫩蜜臀av国产精品网站| 久久久精品视频免费观看| 欧美丰满一区二区免费视频| 求av网址在线观看| 国产精品网站大全| 久久综合国产| 亚洲欧美日韩三级| 国产精品高潮久久久久无| 一级黄色a视频| 少妇av一区二区三区| 亚洲精品第一| 国产树林野战在线播放| 国产乱淫av一区二区三区| 欧美成人国产精品高潮| 日韩欧美国产不卡| 操人在线观看| 蜜桃日韩视频| 日本麻豆一区二区三区视频| 手机看片日韩av| 欧美日本免费一区二区三区| 精品麻豆一区二区三区| 亚洲www视频| 国户精品久久久久久久久久久不卡| 97中文字幕在线观看| 亚洲丶国产丶欧美一区二区三区| 天天干天天爽天天操| 日本一本a高清免费不卡| 日韩精品四区| 亚洲天堂小视频| 都市激情亚洲色图| 国产美女视频一区二区三区| 成人精品aaaa网站| 欧美视频福利| 欧美激情aaa| 91麻豆精品国产91久久久久久久久| 欧美另类tv| 欧美xxxx黑人又粗又长精品| 青椒成人免费视频| 欧美交换国产一区内射| 日韩电视剧在线观看免费网站| 欧美色网在线| japanese在线播放| 2023国产精品自拍| 亚洲中文字幕一区二区| 欧美激情一区二区久久久| 久草成人在线| 麻豆精品国产传媒| 欧美日韩中文字幕在线视频| 欧美jizzhd69巨大| 国内一区二区在线视频观看| 蜜桃视频在线观看一区二区| 欧美成人黄色网| 在线中文字幕日韩| 欧美尿孔扩张虐视频| 亚洲午夜激情影院| 粉嫩老牛aⅴ一区二区三区| 视频免费一区|