使用 React Query 簡化前端 CRUD 應用的數據獲取
構建前端 CRUD 應用起初很容易,但隨著功能的增加,複雜性會迅速提升。對於每個 API 端點,都需要處理狀態管理、同步、緩存和錯誤處理。本文將介紹一個名為 React Query 的庫,以及它如何幫助解決所有這些問題。該庫自稱是“缺失的數據獲取庫”,為你的 React 應用提供“服務器狀態管理”。
我們將使用一個完整的 React Query 演示項目來學習該庫提供的核心功能。然後,你就可以將這些知識應用到自己的項目中。首先,在開始項目設置之前,讓我們先了解一些內容。
關鍵要點
- React Query 3 簡化了 React 應用中的狀態管理和數據獲取,高效地處理緩存、同步和錯誤管理。
- 該庫適用於熟悉 React、React Router 和 REST API 的中高級開發者。
- React Query 3 在 2.x 版本的基礎上增加了新功能和改進,並為升級用戶提供了遷移指南。
- 演示項目中演示的關鍵功能包括基本查詢、分頁查詢和無限查詢,以及創建、更新和刪除操作。
- React Query 的 Devtools 實用程序通過實時可視化內部狀態和流程來輔助調試。
-
cacheTime
和staleTime
等配置選項通過管理數據新鮮度和緩存持續時間來優化性能。 - 該庫支持無限滾動和復雜狀態依賴等高級場景,增強了用戶體驗和開發者體驗。
關於 React Query 3
React Query 是由 Tanner Linsey 創建的一個開源項目。最新的主要版本 React Query 3 於 2020 年 12 月正式發布。在這個新版本中,添加了新功能並改進了現有功能。
需要注意的是,與之前非常流行的 React Query 2.x 版本相比,它有一些重大更改。有一個遷移指南清楚地解釋了這些更改,因為你可能會遇到很多針對舊版本編寫的過時教程。
新版本提供了巨大的改進,許多之前報告的錯誤都已解決。 3.x 版本雖然已準備好用於生產環境,但仍在不斷開發中,並定期修復新發現的錯誤。
前提條件
本文面向中高級前端開發者,他們已經掌握了以下方面的基本技能和知識:
- React
- React Router
- React Hooks
- REST API 數據獲取
在你的開發機器環境中,你需要設置以下內容:
- Node.js
- Git
- REST 客戶端,例如 Postman、Insomnia 或 VS Code 的 REST 擴展
關於項目
我們將分析的演示項目是一個 React 前端應用程序,它將使用 React Query 獲取 REST JSON API 服務器提供的數據。該應用程序僅由五個頁面組成,展示了 React Query 提供的功能。這些功能包括:
- 基本查詢
- 分頁查詢
- 無限查詢
- 創建操作
- 更新操作
- 刪除操作
React Query 提供了更多功能,但本文篇幅有限,無法一一介紹。以下是我們將使用的應用程序的預覽:
項目設置
在我們開始設置之前,我認為最好先簡要了解一下項目中使用的其他依賴項。這些包括:
- Vite:一個非常快速的構建工具
- WindiCSS:一個非常快速的 Tailwind CSS 編譯器
- React Hook Form:一個使用 React hook 的表單構建器和驗證庫
- React Modal:一個可訪問的模態組件
- Axios:一個基於 Promise 的瀏覽器 HTTP 客戶端
- JSON Server:一個完整的偽造 REST API 服務器
要在你自己的機器上設置 React Query 演示應用程序,請執行以下說明:
# 克隆项目 git clone git@github.com:sitepoint-editors/react-query-demo.git # 导航到项目目录 cd react-query-demo # 安装包依赖项 npm install # 为 json-server 设置数据库文件 cp api/sample.db.json api/db.json # 启动 json-server npm run json-server
json-server 使用的數據庫文件包含一個用戶數組。當你執行 npm run json-server
時,一個偽造的 API 服務器將在端口 3004 上啟動。執行 GET 請求將產生以下示例 JSON 響應:
[ { "id": 1, "first_name": "Siffre", "last_name": "Timm", "email": "stimmes0@nasa.govz", "gender": "Male" }, { "id": 2, "first_name": "Fonzie", "last_name": "Coggen", "email": "fcoggen1@weather.com", "gender": "Female" }, { "id": 3, "first_name": "Shell", "last_name": "Kos", "email": "skos2@prweb.com", "gender": "Female" } ]
接下來,啟動將運行前端代碼的開發服務器:
# 在另一个终端中,启动 React 开发服务器 npm run dev
轉到你的瀏覽器並打開 http://localhost:3000
以訪問應用程序。你應該會有與上面預覽中相同的體驗。請確保執行以下任務,以便徹底探索應用程序的功能:
- 查看基本查詢頁面(主頁)。
- 訪問分頁頁面並與“上一頁”和“下一頁”按鈕進行交互。
- 訪問無限頁面並與“加載更多”按鈕進行交互。
- 返回基本查詢頁面並單擊“創建用戶”按鈕。你將被定向到“創建用戶”頁面。填寫表單並單擊“保存”按鈕。
- 在用戶表中,找到“編輯”圖標。單擊它。這將帶你到“編輯用戶”頁面。進行任何你喜歡的更改,然後點擊“保存”按鈕。
- 在用戶表中,找到“刪除”圖標。單擊它。這將啟動一個模態對話框,要求你確認刪除操作。單擊“刪除”按鈕以確認。
完成所有上述任務後,我們可以開始對項目進行分解。請查看項目結構,以便了解每個組件和視圖的位置。我將在本文中提供這些組件的簡化版本,以便你了解在項目中使用 React Query 的基礎知識。
安裝 React Query
可以使用以下命令在空白或現有 React 項目中安裝 React Query:
# 克隆项目 git clone git@github.com:sitepoint-editors/react-query-demo.git # 导航到项目目录 cd react-query-demo # 安装包依赖项 npm install # 为 json-server 设置数据库文件 cp api/sample.db.json api/db.json # 启动 json-server npm run json-server
該包包含你所需的一切——包括 Devtools 實用程序功能,我們將在後面的部分中探討。安裝包後,你需要更新你的頂級組件——App.jsx
——如下所示:
[ { "id": 1, "first_name": "Siffre", "last_name": "Timm", "email": "stimmes0@nasa.govz", "gender": "Male" }, { "id": 2, "first_name": "Fonzie", "last_name": "Coggen", "email": "fcoggen1@weather.com", "gender": "Female" }, { "id": 3, "first_name": "Shell", "last_name": "Kos", "email": "skos2@prweb.com", "gender": "Female" } ]
QueryClientProvider
的任何子組件都將能夠訪問 React Query 庫提供的 hook。我們將在本文中使用的 hook 是:
useQuery
useInfiniteQuery
useMutation
useQueryClient
以下是一個更新後的(簡化版)App.jsx
,其中包含我們將使用的子視圖:
# 在另一个终端中,启动 React 开发服务器 npm run dev
(後續內容,請根據你的要求繼續翻譯剩餘部分,包括UI組件、基本查詢、分頁查詢、無限查詢、Mutations等章節。)
以上是REACT查詢3:獲取和管理數據的指南的詳細內容。更多資訊請關注PHP中文網其他相關文章!

從C/C 轉向JavaScript需要適應動態類型、垃圾回收和異步編程等特點。 1)C/C 是靜態類型語言,需手動管理內存,而JavaScript是動態類型,垃圾回收自動處理。 2)C/C 需編譯成機器碼,JavaScript則為解釋型語言。 3)JavaScript引入閉包、原型鍊和Promise等概念,增強了靈活性和異步編程能力。

不同JavaScript引擎在解析和執行JavaScript代碼時,效果會有所不同,因為每個引擎的實現原理和優化策略各有差異。 1.詞法分析:將源碼轉換為詞法單元。 2.語法分析:生成抽象語法樹。 3.優化和編譯:通過JIT編譯器生成機器碼。 4.執行:運行機器碼。 V8引擎通過即時編譯和隱藏類優化,SpiderMonkey使用類型推斷系統,導致在相同代碼上的性能表現不同。

JavaScript在現實世界中的應用包括服務器端編程、移動應用開發和物聯網控制:1.通過Node.js實現服務器端編程,適用於高並發請求處理。 2.通過ReactNative進行移動應用開發,支持跨平台部署。 3.通過Johnny-Five庫用於物聯網設備控制,適用於硬件交互。

我使用您的日常技術工具構建了功能性的多租戶SaaS應用程序(一個Edtech應用程序),您可以做同樣的事情。 首先,什麼是多租戶SaaS應用程序? 多租戶SaaS應用程序可讓您從唱歌中為多個客戶提供服務

本文展示了與許可證確保的後端的前端集成,並使用Next.js構建功能性Edtech SaaS應用程序。 前端獲取用戶權限以控制UI的可見性並確保API要求遵守角色庫

JavaScript是現代Web開發的核心語言,因其多樣性和靈活性而廣泛應用。 1)前端開發:通過DOM操作和現代框架(如React、Vue.js、Angular)構建動態網頁和單頁面應用。 2)服務器端開發:Node.js利用非阻塞I/O模型處理高並發和實時應用。 3)移動和桌面應用開發:通過ReactNative和Electron實現跨平台開發,提高開發效率。

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

Atom編輯器mac版下載
最受歡迎的的開源編輯器

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)