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

vue使用Pinia的五個實用技巧分享

 更新時間:2023年11月23日 11:01:33   作者:王大冶  
這篇文章主要為大家詳細(xì)介紹了vue中使用Pinia是五個實用技巧,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價值,感興趣的小伙伴可以跟隨小編一起了解一下

1.不要創(chuàng)建無用的 getter

你并不需要為所有事情使用 getter。在 Vuex 中有一個普遍的誤解,認(rèn)為你應(yīng)該總是通過 getter 訪問狀態(tài)。

這是不正確的。

當(dāng)你需要從狀態(tài)中計算出某些東西時,getter 是有用的,例如,如果你有一個待辦事項列表,想知道有多少已完成,你可以為此創(chuàng)建一個 getter。

在生產(chǎn)代碼中經(jīng)常看到過這樣的代碼:

export default Vuex.Store({
  state: () => ({ counter: 0 }),
  getters: {
    // 完全無用的 getter
    getCount: state => state.counter,
  },
})

這在 Vuex 中只是不必要的樣板代碼,在 Pinia 中也是如此。你可以直接訪問狀態(tài):

const counterStore = useCounterStore()
counterStore.counter // 0 ?

PS:大多數(shù)時候你不需要 storeToRefs()(或 toRef())。你可以直接使用 store,Vue 的響應(yīng)式真的很方便 。

2. 在 Option Stores 中使用組合式函數(shù)

你可以在 option stores 中使用一些組合式函數(shù),特別是那些持有狀態(tài)且可寫的組合式函數(shù)。例如,你可以使用 @vueuse/coreuseLocalStorage() 將一些狀態(tài)存儲在瀏覽器的本地存儲中。

import { useLocalStorage } from '@vueuse/core'
const useAuthStore = defineStore('auth', {
  state: () => ({
    user: useLocalStorage('pinia/user/login', 'alice'),
  }),
})

或者使用 refDebounced()ref 的更改進(jìn)行防抖處理:

import { refDebounced } from '@vueuse/core'
const useSearchStore = defineStore('search', {
  state: () => ({
    user: {
      text: refDebounced(/* ... */),
    },
  }),
})

3.在 Setup Stores 中使用復(fù)雜的組合式函數(shù)

在 Setup stores 中,你可以使用任何你想要的組合式函數(shù)。你可以連接到 websocket、藍(lán)牙處理或甚至游戲手柄!

import { useWebSocket } from '@vueuse/core'
export const useServerInfoStore = defineStore('server-info', () => {
  const { status, data, send, open, close } = useWebSocket('ws://websocketurl')
  return {
    status,
    data,
    send,
    open,
    close,
  }
})

Pinia 會自動識別哪些是狀態(tài)、getter 或動作。記住,必須從 setup 函數(shù)返回所有狀態(tài)屬性。

在 setup stores 中使用 inject()

你可以在 setup stores 中使用 inject() 來訪問應(yīng)用級別提供的變量,如路由器實例:

import { useRouter } from 'vue-router'
export const useAuthStore('auth', () => {
  const router = useRouter()
  function logout() {
    // 登出用戶
    return router.push('/login')
  }
  return {
    logout
  }
})

使用嵌套 Stores 創(chuàng)建私有狀態(tài)

setup stores 的一個黃金規(guī)則是返回每一個狀態(tài)片段:

export const useAuthStore('auth', () => {
  const user = ref<User | null>(null)
  const token = ref<string | null>(null)
  // 我們必須返回 user 和 token
  return {
    user,
    token,
  }
})

但如果我們想要隱藏一些 store 中的狀態(tài)怎么辦?我們可以創(chuàng)建一個包含私有狀態(tài)的嵌套 store:

export const usePrivateAuthState('auth-private', () => {
  const token = ref<string | null>(null)
  return {
    token,
  }
})
export const useAuthStore('auth', () => {
  const user = ref<User | null>(null)
  const privateState = usePrivateAuthState()
  privateState.token // 僅在此 store 中可訪問
  return {
    user,
  }
})

在 SSR 中使用僅客戶端狀態(tài)

服務(wù)器端渲染(SSR)是提高應(yīng)用性能的絕佳方式。然而,與僅客戶端應(yīng)用相比,它帶來了一些額外的困難。例如,你無法訪問 window、document 或任何其他特定于瀏覽器的 API,如本地存儲。

在 Option Stores 中,這要求你使用 hydrate 選項告訴 Pinia 某些狀態(tài)不應(yīng)在客戶端上進(jìn)行 hydrate

import { useLocalStorage } from '@vueuse/core'
const useAuthStore = defineStore('auth', {
  state: () => ({
    user: useLocalStorage('pinia/user/login', 'alice'),
  }),
  hydrate(state, initialState) {
    state.user = useLocalStorage('pinia/user/login', 'alice')
  },
})

在 Setup Stores 中,你可以使用 skipHydrate 輔助函數(shù)標(biāo)記某些狀態(tài)為僅客戶端狀態(tài):

import { defineStore, skipHydrate } from 'pinia'
const useAuthStore = defineStore('auth', () => {
  const user = skipHydrate(useLocalStorage('pinia/user/login', 'alice'))
  return { user }
})

到此這篇關(guān)于vue使用Pinia的五個實用技巧分享的文章就介紹到這了,更多相關(guān)Pinia技巧內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue3使用element-plus實現(xiàn)彈窗效果

    Vue3使用element-plus實現(xiàn)彈窗效果

    本文主要介紹了Vue3使用element-plus實現(xiàn)彈窗效果,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • Vue數(shù)據(jù)驅(qū)動表單渲染,輕松搞定form表單

    Vue數(shù)據(jù)驅(qū)動表單渲染,輕松搞定form表單

    這篇文章主要介紹了Vue數(shù)據(jù)驅(qū)動表單渲染,輕松搞定form表單,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-07-07
  • Vue+elementUI實現(xiàn)多圖片上傳與回顯功能(含回顯后繼續(xù)上傳或刪除)

    Vue+elementUI實現(xiàn)多圖片上傳與回顯功能(含回顯后繼續(xù)上傳或刪除)

    這篇文章主要介紹了Vue+elementUI實現(xiàn)多圖片上傳與回顯功能(含回顯后繼續(xù)上傳或刪除),本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-03-03
  • element Table表格組件多字段(多列)排序方法

    element Table表格組件多字段(多列)排序方法

    最近需要做個需求,需要做到element Table表格組件多字段(多列)排序,本文就詳細(xì)的介紹一下方法,感興趣的可以了解一下
    2021-09-09
  • vue移動端使用appClound拉起支付寶支付的實現(xiàn)方法

    vue移動端使用appClound拉起支付寶支付的實現(xiàn)方法

    這篇文章主要介紹了vue移動端使用appClound拉起支付寶支付的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • 詳解vue如何給特殊字段設(shè)置插槽

    詳解vue如何給特殊字段設(shè)置插槽

    這篇文章主要為大家詳細(xì)介紹了vue如何實現(xiàn)給特殊字段設(shè)置插槽,文中的示例代碼講解詳細(xì),具有一定的借鑒價值,有需要的小伙伴可以學(xué)習(xí)一下
    2023-09-09
  • 用了這么久的Vue3你真的了解Proxy了嗎

    用了這么久的Vue3你真的了解Proxy了嗎

    Proxy是ES6引入的一個新特性,它允許你創(chuàng)建一個代理對象,用于攔截對目標(biāo)對象的訪問,但用了這么久的vue3,你真的懂Proxy嗎,本文就來和大家深入聊聊Proxy吧
    2023-06-06
  • Vue+Vux項目實踐完整代碼

    Vue+Vux項目實踐完整代碼

    本文給大家分享一段詳細(xì)的代碼給大家介紹Vue+Vux項目實踐思路,需要的朋友可以參考下
    2017-11-11
  • 解決vue-router中的query動態(tài)傳參問題

    解決vue-router中的query動態(tài)傳參問題

    下面小編就為大家分享一篇解決vue-router中的query動態(tài)傳參問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • vue實現(xiàn)簡單全選和反選功能

    vue實現(xiàn)簡單全選和反選功能

    這篇文章主要為大家詳細(xì)介紹了vue實現(xiàn)簡單全選和反選功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-09-09

最新評論