精品欧美一区二区三区在线观看 _久久久久国色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)

免费黄色网址在线观看| 中文字幕在线观看高清| 午夜欧洲一区| 在线视频亚洲一区| 四虎精品欧美一区二区免费| 色噜噜在线播放| 日本中文字幕一区二区视频| 欧美国产精品日韩| 成人黄色a级片| jizz性欧美23| 欧美日韩国产中文| 日韩av高清在线看片| 中文字幕在线视频区| 不卡欧美aaaaa| 国产精品视频久久| 日韩三级视频在线播放| 国产精品久久久久久影院8一贰佰| 精品国产91久久久久久久妲己| 在线免费视频a| 丁香花在线电影| 国产精品你懂的在线| 久久久www免费人成黑人精品| 艳妇乳肉豪妇荡乳av| 国产日韩欧美三区| 欧美国产日本在线| 性欧美疯狂猛交69hd| 狠狠做深爱婷婷综合一区| 亚洲成人av片| 天天综合成人网| 欧美va在线观看| 欧美性猛交xxxx富婆| 大伊香蕉精品视频在线| 黄在线免费观看| 日本一区二区不卡视频| 久久影视中文粉嫩av| 丰满少妇高潮在线观看| 国产精品一区专区| 国产欧美一区二区三区久久| 亚洲精品成人在线视频| 在线日韩av| 欧美激情精品久久久久久蜜臀| 九九这里只有精品视频| 日韩精品午夜| 在线免费观看羞羞视频一区二区| free性中国hd国语露脸| 久久婷婷国产| 亚洲电影免费观看高清完整版在线观看 | 欧美高清视频一二三区| 国产裸体免费无遮挡| 黑人精品一区| 色综合久久久久综合体| 成熟了的熟妇毛茸茸| www在线观看黄色| 亚洲一区二区三区四区在线| 欧美中文字幕在线观看视频| 在线观看免费视频你懂的| 亚洲女厕所小便bbb| 日本一道在线观看| 色yeye免费人成网站在线观看| 亚洲精品久久嫩草网站秘色| 国产欧美123| 视频在线观看入口黄最新永久免费国产 | 欧美成人ⅴideosxxxxx| 日韩欧美999| 久久精品视频91| 成人福利视频| 欧美日韩免费一区二区三区 | 成人性视频网站| 国产精品免费一区二区三区| 日韩中文字幕免费在线观看| 26uuu成人网一区二区三区| 青青成人在线| 日本三级视频在线观看| 亚洲精品中文在线影院| r级无码视频在线观看| 欧美激情网站| 欧美日韩一区二区三区在线看| 中文av字幕在线观看| 蜜桃精品一区二区三区| 欧美精品一区二区三区蜜臀| 久久精品一区二区免费播放| 色999国产精品| 欧美美最猛性xxxxxx| 午夜毛片在线观看| 免费观看成人av| 99在线观看视频网站| 手机亚洲第一页| 国产精品人妖ts系列视频| 天天做天天躁天天躁| 在线天堂资源| 日韩一区二区三区免费观看| 午夜一区二区三区免费| 国产精品久久久久久影院8一贰佰 国产精品久久久久久麻豆一区软件 | 国产精品成人在线观看| 亚洲色成人www永久在线观看| 自拍视频在线看| 91.com视频| 黄色录像a级片| 天天做天天爱天天综合网2021| 国语自产精品视频在线看抢先版图片| 国产精品xxxxxx| 成人激情综合网站| 超碰在线免费观看97| 国产盗摄——sm在线视频| 欧美日韩精品欧美日韩精品一| 日本wwww色| 色综合久久一区二区三区| 午夜精品久久久久久99热| 影音先锋黄色网址| 91欧美一区二区| 在线观看av的网址| 99只有精品| 亚洲免费av电影| 精品无码久久久久久久| 六月丁香综合在线视频| 欧美精品一区二区三区在线四季 | 高清日韩av电影| 亚洲一卡二卡三卡四卡无卡久久| 中文av一区二区三区| 欧美日韩一区二区三区四区不卡| 欧美大片va欧美在线播放| 中文字幕av免费观看| 久久综合九色综合97_久久久| 特级西西444| 偷拍自拍亚洲| 影音先锋欧美精品| 一区二区三区福利视频| 国产精品一区二区在线看| 亚洲欧洲一区二区在线观看| 韩国久久久久久| 日韩久久精品电影| 日韩精品成人一区| 不卡一卡二卡三乱码免费网站| 免费的av在线| 99久久久国产| 精品国偷自产在线| 国产一区二区视频免费观看| 中文字幕的久久| 香蕉视频网站入口| 波多野结衣在线播放一区| 日韩av免费在线看| 四虎在线视频| 一本色道a无线码一区v| 最近中文字幕无免费| 国产亚洲毛片| 欧美18视频| 户外露出一区二区三区| 亚洲人成在线观看| 中文字幕91爱爱| 中文字幕在线不卡视频| 国产无遮挡猛进猛出免费软件| 日韩毛片视频| 亚洲一区二区三区sesese| 成人无遮挡免费网站视频在线观看| 欧美裸体bbwbbwbbw| 国产福利视频网站| 成人一区二区在线观看| 国产69精品久久久久久久| 免费福利视频一区| 欧洲美女免费图片一区| 国产在线观看免费| 在线观看网站黄不卡| 美国黄色片视频| 国产成人精品一区二区三区网站观看| 亚洲理论电影在线观看| 神马香蕉久久| 国产精品免费在线免费| 黄视频网站在线看| 欧美精品一区二区三| 视频一区二区三区四区五区| 国产欧美精品一区| 欧美视频亚洲图片| 影院欧美亚洲| 日韩hmxxxx| 国产精品高清一区二区| 国产做受高潮69| 黄色在线小视频| 91精品国产综合久久久蜜臀图片| 国产一级中文字幕| 国产亚洲一区二区三区| 亚洲精品在线视频播放| 亚洲午夜一级| 日韩av高清| 色妞ww精品视频7777| 浅井舞香一区二区| 国产丝袜在线| 国产视频丨精品|在线观看| 影音先锋国产资源| 亚洲一区免费观看| 国产又粗又黄又猛| 丁香婷婷综合色啪| 色婷婷综合网站| 亚洲日本久久| 一本二本三本亚洲码| 伊人久久大香线蕉综合网站| 91在线高清视频| 日本电影欧美片| 欧美激情在线视频二区| 福利视频在线看| 亚洲国产精彩中文乱码av| 中文字幕一区二区三区四区视频| 亚洲成人av一区二区三区| 特级西西人体高清大胆| 99精品国产视频| 日本55丰满熟妇厨房伦| 日韩一区欧美二区| av免费观看网| 天天做天天爱天天综合网| 日本一区二区在线视频观看| 9999久久久久| 成人欧美一区二区三区在线| 天天免费亚洲黑人免费| 性色av一区二区三区在线观看| 美女免费久久| 中文字幕av一区二区| 天天干天天爽天天操| 欧美一级片在线| 亚洲天堂国产精品| 色婷婷激情久久| 精品国产乱码一区二区| 亚洲高清不卡在线观看| 国产精品视频一区二区三| 国产欧美日韩激情| 精品成人av一区二区三区| www.日韩精品| 久久精品aⅴ无码中文字字幕重口| 精品无人码麻豆乱码1区2区 | 日韩中文字幕精品| 黄色软件在线| 亚洲人成在线免费观看| 香蕉久久国产av一区二区| 精品国产91久久久久久久妲己| www.国产麻豆| 日韩视频在线永久播放| 精品毛片一区二区三区| 69p69国产精品| 国产一区二区三区视频免费观看 | 性中国古装videossex| 欧美日韩一级片在线观看| 日本一本在线观看| 色94色欧美sute亚洲线路一久 | 四虎影视国产在线视频| 超碰97人人做人人爱少妇| 麻豆视频在线| 久久综合久中文字幕青草| 国产在线观看免费麻豆| 久久成人av网站| 日本在线观看大片免费视频| 欧美精品在线观看| 丰乳肥臀在线| 欧美亚洲第一页| 性欧美hd调教| 国产精品一区二区久久久| 日本国产亚洲| 91在线精品播放| 高潮按摩久久久久久av免费| 国产精品二区在线观看| 欧美jizz19性欧美| 欧美一二三区| 国产电影一区二区在线观看| 欧美另类videosbestsex日本| 韩日欧美一区| 97av视频在线观看| 免费观看日韩av| 黄色片子免费看| 成人免费视频一区| 麻豆av免费观看| 国产精品久久久久久久久快鸭 | 欧美三级视频在线播放| 亚洲无码久久久久久久| 欧美第一区第二区| 青青草av免费在线观看| 日韩在线观看网址| 免费影视亚洲| 国产成人一区二区三区电影| 精品视频在线播放一区二区三区| 国产精品一区在线播放| 国产一区二区三区四区五区| 亚洲小说欧美另类激情| 亚洲国产二区| 中文字幕免费高清在线| 成人免费视频网站在线观看| 一区二区黄色片| 亚洲黄色免费网站| 久久99国产综合精品免费| 欧美日本视频在线| 天天爽夜夜爽夜夜爽| 色香阁99久久精品久久久| 日韩123区| 国产精品爽爽爽爽爽爽在线观看| 亚洲一区二区免费在线观看| 青娱乐国产91| 亚洲国产99| 99中文字幕在线| 2020国产精品自拍| 亚洲国产精品久| 在线视频一区二区三区| 人妻夜夜爽天天爽| 久久精品中文字幕免费mv| 日韩脚交footjobhdboots| 91中文字幕在线| 欧美日韩国产一区二区三区不卡| 真实国产乱子伦对白视频| 免费亚洲电影在线| 给我看免费高清在线观看| 亚洲精品综合在线| 亚洲视频一区二区三区四区| 亚洲精品wwwww| 色呦呦在线视频| 国产欧美日韩丝袜精品一区| 亚洲免费专区| 欧美视频在线免费播放| 国产精品主播直播| 国产小视频你懂的| 91久久香蕉国产日韩欧美9色| 黄色成人一级片| 久99九色视频在线观看| 久久久人成影片一区二区三区在哪下载| 5g国产欧美日韩视频| 99视频精品全部免费在线视频| 热久久精品免费视频| 91丨porny丨在线| 国产精彩视频在线| 日韩免费一区二区| v片在线观看| 91九色国产视频| 香蕉综合视频| 日本美女视频一区| 国产精品美女久久久久高潮| 波多野结衣一二区| 国产午夜精品全部视频播放 | av网站在线免费| 国产欧美 在线欧美| 成人精品视频| 超碰在线播放91| 中文成人综合网| 曰批又黄又爽免费视频| 日韩最新中文字幕电影免费看| 国产精品毛片久久久久久久久久99999999| 免费99视频| 久久久噜噜噜久久狠狠50岁| 天天躁日日躁aaaa视频| 日本道在线观看一区二区| 国产免费av高清在线| 国产精品美女久久久久久免费 | 一本一道久久a久久| 国产一二三四区在线观看| 国产黄色精品视频| 国产亚洲精品成人| 亚洲成年人在线播放| 日本黄色免费在线| 日本视频一区在线观看| 日本亚洲最大的色成网站www| 最新中文字幕av| 7777精品伊人久久久大香线蕉经典版下载| 日本精品在线| 99视频国产精品免费观看| 在线精品亚洲| 丰满少妇一区二区三区| 欧美在线不卡视频| 久久黄色美女电影| 99三级在线| 蜜桃视频一区| 999精品在线视频| 精品国产制服丝袜高跟| 国产拍在线视频| 色一情一乱一伦一区二区三区| 精品写真视频在线观看| 久久免费视频99| 亚洲精品影视在线观看| 国精品产品一区| www成人免费| 久久一夜天堂av一区二区三区| 中文字幕av影视| 欧美日韩国产999| 伊人精品一区| 红桃视频一区二区三区免费| 午夜精品爽啪视频| 都市激情在线视频| 成人国产一区二区| 丝袜亚洲另类丝袜在线| 少妇人妻丰满做爰xxx| 日韩经典一区二区三区| 欧美a一级片| 免费观看国产精品视频| 国产三级一区二区三区| 亚洲狼人综合网| 国产精品成人在线| 亚洲成人在线| 大吊一区二区三区| 亚洲白虎美女被爆操| 日韩制服诱惑| 你真棒插曲来救救我在线观看| 国产欧美日韩亚州综合 | 激情综合婷婷| 成年人视频网站免费观看| 亚洲欧美日韩国产成人精品影院| 日韩一区av| 成人免费视频网站| 久久精品国产精品青草|