某些場景下建議vue query代替pinia原理解析
前言
在 vue3 中,狀態(tài)管理都是用的 pinia 來處理和存儲從服務(wù)端獲取的數(shù)據(jù)。使用 react 的同學(xué)應(yīng)該對 swr
、react-query
、ahooks 的 useRequest(前兩者的模仿)并不陌生,這些是專門用來處理數(shù)據(jù)請求的, 能夠幫助你處理得到的數(shù)據(jù)、loading、error,還有緩存數(shù)據(jù)的功能等等。不止有 react-query
、vue-query
, 還有 svelte-query
和 solid-query
,這些其實(shí)都是同一個作者,是在同一個庫中,通過它的核心底層來實(shí)現(xiàn)各個框架的功能。query 文檔地址
使用區(qū)別
pinia
// 根文件 const pinina = createPinia(); app.use(pinia);
獲取和修改用戶信息,需要維護(hù) user 狀態(tài), 頁面中需要維護(hù)兩個 loading 狀態(tài)。
const useStore = defineStore('main', { state: () => ({ user: null, }), actions: { async getUser() { try { const user = await axios.get("/api/user"); this.user = user; } catch(err) { // } }, async updateUser(data) { try { const res = await axios.post("/api/user", data); // do something // this.user = res; } catch(err) { // } } }, })
<script setup> const getUserLoading = ref(false); const updateUserLoading = ref(false); // 獲取用戶信息 onMounted(async() => { getUserLoading.value = true; await store.getUser(); getUserLoading.value = false; }) // 修改用戶信息 const updateUser = async () => { updateUserLoading.value = true; await store.updateUser({ username: "123" }) updateUserLoading.value = false; } </script>
vue-query
// 根文件 app.use(VueQueryPlugin)
// 新建一個文件 useUserQuery.js。需要必傳兩個值,queryKey 是緩存數(shù)據(jù)需要的唯一值,是個數(shù)組,我的習(xí)慣是直接用 api 地址。queryFn 是請求的方法。 // useUserQuery.js const api = "/api/user"; export const useUserQuery = (props) => useQuery({ queryKey: [api], queryFn: () => axios.get(api), ...props }); // 新建一個文件 useUserMutation.js,因?yàn)槭切薷臄?shù)據(jù),并沒有緩存這個概念,所以不需要唯一值,只需要傳入請求方法即可。 // useUserMutation.js const api = "/api/user"; export const useUserMutation = (props) => useMutation({ mutationFn: (data) => axios.post(api, data), ...props });
<script setup> // 獲取用戶信息 const { data, isLoading } = useUserQuery({ onSuccess: (data) => { // 成功回調(diào) }, onError: (error) => { // 可以配置全局 onError 錯誤處理,這里不做介紹 }, }); const { isLoading, mutate } = useUserMutation(); // 修改用戶信息 const updateUser = () => { mutate({ username: "123" }) } </script>
如果你在另一個地方也需要用到這個 user 數(shù)據(jù),你可以再調(diào)用一次 useUserQuery,因?yàn)橹坝芯彺媪?,所以不會發(fā)出請求,但可以拿到數(shù)據(jù)?;蛘呤褂?queryClient 傳入唯一值來獲取數(shù)據(jù)。
const queryClient = useQueryClient(); const data = queryClient.getQueryData(["/api/user"])
總結(jié)
先來看看官方文檔中怎么說 # Does TanStack Query replace Vuex, Pinia or other global state managers?
vue-query 只適用于存儲從服務(wù)端獲取的數(shù)據(jù),如果有另外的數(shù)據(jù)需要存儲還是要用到 pinia,但是這種數(shù)據(jù)是比較少的,這樣也可以使得 pinia 中的代碼量減少很多并簡潔。當(dāng)然這里介紹的 vue-query 的 api 是最簡單的,你能想到的功能它基本都有,感興趣的可以查看文檔。
趨勢
在 react 中使用 swr、react-query 是大勢所趨,可以從 npm 下載量來看出來。相信今后在 vue 中 vue-query 也會有越來越多的使用,因?yàn)榱硗馊罂蚣芏际歉S react 走的 hooks 的思想。
以上就是某些場景下建議vue query代替pinia原理解析的詳細(xì)內(nèi)容,更多關(guān)于vue query代替pinia原理的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
vue項(xiàng)目使用高德地圖時報錯:AMap?is?not?defined解決辦法
這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目使用高德地圖時報錯:AMap?is?not?defined的解決辦法,"AMap is not defined"是一個錯誤提示,意思是在代碼中沒有找到定義的AMap,需要的朋友可以參考下2023-12-12vue3項(xiàng)目typescript如何export引入(imported)的interface問題
這篇文章主要介紹了vue3項(xiàng)目typescript如何export引入(imported)的interface問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-06-06vue 實(shí)現(xiàn)模糊檢索并根據(jù)其他字符的首字母順序排列
這篇文章主要介紹了vue 實(shí)現(xiàn)模糊檢索,并根據(jù)其他字符的首字母順序排列,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-09-09使用element+vuedraggable實(shí)現(xiàn)圖片上傳拖拽排序
這篇文章主要為大家詳細(xì)介紹了使用element+vuedraggable實(shí)現(xiàn)圖片上傳拖拽排序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-04-04圖文詳解如何在vue3+vite項(xiàng)目中使用svg
SVG指可伸縮矢量圖形,用來定義用于網(wǎng)絡(luò)的基于矢量的圖形,下面這篇文章主要給大家介紹了關(guān)于如何在vue3+vite項(xiàng)目中使用svg的相關(guān)資料,需要的朋友可以參考下2021-11-11