欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

某些場景下建議vue query代替pinia原理解析

 更新時間:2023年02月08日 14:54:44   作者:馬格納斯  
這篇文章主要為大家介紹了某些場景下建議vue-query代替pinia原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

前言

在 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-querysolid-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解決辦法

    vue項(xiàng)目使用高德地圖時報錯:AMap?is?not?defined解決辦法

    這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目使用高德地圖時報錯:AMap?is?not?defined的解決辦法,"AMap is not defined"是一個錯誤提示,意思是在代碼中沒有找到定義的AMap,需要的朋友可以參考下
    2023-12-12
  • vue3項(xiàng)目typescript如何export引入(imported)的interface問題

    vue3項(xiàng)目typescript如何export引入(imported)的interface問題

    這篇文章主要介紹了vue3項(xiàng)目typescript如何export引入(imported)的interface問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • vue.js事件處理器是什么

    vue.js事件處理器是什么

    什么是vue.js事件處理器?這篇文章主要介紹了vue.js事件處理器的相關(guān)資料
    2017-03-03
  • Vue組件基礎(chǔ)操作介紹

    Vue組件基礎(chǔ)操作介紹

    這篇文章主要介紹了Vue組件基礎(chǔ)操作,組件是vue.js最強(qiáng)大的功能之一,而組件實(shí)例的作用域是相互獨(dú)立的,這就意味著不同組件之間的數(shù)據(jù)無法相互進(jìn)行直接的引用
    2023-01-01
  • Vue+elementUI下拉框自定義顏色選擇器方式

    Vue+elementUI下拉框自定義顏色選擇器方式

    這篇文章主要介紹了Vue+elementUI下拉框自定義顏色選擇器方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • vue 實(shí)現(xiàn)模糊檢索并根據(jù)其他字符的首字母順序排列

    vue 實(shí)現(xiàn)模糊檢索并根據(jù)其他字符的首字母順序排列

    這篇文章主要介紹了vue 實(shí)現(xiàn)模糊檢索,并根據(jù)其他字符的首字母順序排列,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-09-09
  • 使用element+vuedraggable實(shí)現(xiàn)圖片上傳拖拽排序

    使用element+vuedraggable實(shí)現(xiàn)圖片上傳拖拽排序

    這篇文章主要為大家詳細(xì)介紹了使用element+vuedraggable實(shí)現(xiàn)圖片上傳拖拽排序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • 詳解Vue 單文件組件的三種寫法

    詳解Vue 單文件組件的三種寫法

    這篇文章主要介紹了詳解Vue 單文件組件的三種寫法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • 圖文詳解如何在vue3+vite項(xiàng)目中使用svg

    圖文詳解如何在vue3+vite項(xiàng)目中使用svg

    SVG指可伸縮矢量圖形,用來定義用于網(wǎng)絡(luò)的基于矢量的圖形,下面這篇文章主要給大家介紹了關(guān)于如何在vue3+vite項(xiàng)目中使用svg的相關(guān)資料,需要的朋友可以參考下
    2021-11-11
  • 詳解vue掛載到dom上會發(fā)生什么

    詳解vue掛載到dom上會發(fā)生什么

    這篇文章主要介紹了詳解vue掛載到dom上會發(fā)生什么,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01

最新評論