<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
全域性狀態,用於在所有元件中,同步資料。
在整個應用程式中存取的資料(且不需要被持久化),例如導航欄中顯示的使用者資訊,以及需要通過頁面保留的資料,例如一個非常複雜的多步驟表格。
簡單一句介紹,vuex的升級版,拋棄了煩人的Mutation。
下面我們以一個管理平臺的員工賬號資訊為例,展示Pinia的使用方式。
本文作者認為setup
是更好的組織程式碼的方式,所以都用setup
編寫下面的範例。
安裝和掛載部分,直接看檔案。
import { defineStore } from 'pinia' // 第一個引數是應用程式中 store 的唯一 id export const useUserStore = defineStore('user', { // other options... })
import { useUserStore } from '@/stores/user' export default { setup() { const userStore = useUserStore() return { // 您可以返回整個 store 範例以在模板中使用它 userStore, } }, }
(如果習慣用選項式API,還是可以配合map helpers,宣告各種map來存取store。)
直接解構會破壞響應式,需要用storeToRefs()
提取屬性並保持響應式。
import { storeToRefs } from 'pinia' export default defineComponent({ setup() { const userStore = useUserStore() // ❌ 這不起作用,因為它會破壞響應式 // 這和從 props 解構是一樣的 const { userName } = userStore // 這樣可以保持響應式 const { userId } = storeToRefs(userStore) userName // "lucio" userId // "001" return { // 一直會是 "lucio" userName, // 這將是響應式的 userId, // 這將是響應式的 realUserName: computed(() => userStore.userName), } }, })
返回初始狀態的函數。
我們補全一下上面的定義Store部分的程式碼。
import { defineStore } from 'pinia' // 第一個引數是應用程式中 store 的唯一 id export const useUserStore = defineStore('user', { state: () => { return { // 所有這些屬性都將自動推斷其型別 userName: 'lucio', userId: '001', } }, })
const userStore = useUserStore() userStore.userId = '002' userStore.$reset() return { userStore }
$patch
修改多個資料,引數可以是物件或者函數。// 一次修改多個資料 userStore.$patch({ userId: '002', userName: 'lucy', }) // 適合對陣列進行修改 userStore.$patch((state) => { state.roles.push({ name: 'admin', priority: 1 }) })
userStore.$state = { userId: '002', userName: 'lucy'} // 或者通過pinia範例替換整個應用程式的狀態 pinia.state.value = {}
可以通過 store 的 $subscribe()
方法檢視狀態及其變化,其只在patch之後觸發一次。
預設情況下,元件解除安裝後,訂閱會被刪除。如果想保留,設定設定項detached為true。
userStore.$subscribe((mutation, state) => { // import { MutationType } from 'pinia' mutation.type // 'direct' | 'patch object' | 'patch function' // 與 userStore.$id 相同 mutation.storeId // 'user' // 僅適用於 mutation.type === 'patch object' mutation.payload // 修補程式物件傳遞給 to userStore.$patch() // 每當它發生變化時,將整個狀態持久化到本地儲存 localStorage.setItem('user', JSON.stringify(state)) }, { detached: true }, // detached為true,解除安裝元件後保留訂閱 )
返回狀態的計算值。
import { defineStore } from 'pinia' // 第一個引數是應用程式中 store 的唯一 id export const useUserStore = defineStore('user', { state: () => { return { // 所有這些屬性都將自動推斷其型別 userName: 'lucio', userId: '001', } }, getters: { // 自動推斷返回型別為字串 userText: (state) => `User: ${state.userName}`, // 也可以使用其他getter, 用this存取store範例,必須要定義返回型別 userTextPlus: (): string => `The name of ${this.userText}`, } })
直接用store的範例存取。
userStore.userText
(getters也可以傳遞引數,不是很常用的場景,這裡就不範例了。)
(在A store中,也可以使用B store的getter)
相當於元件中的methods,適合用於定義元件的業務邏輯。
下面我們繼續補全上面的範例,在userStore中通過網路請求獲取使用者資料。
import { defineStore } from 'pinia' export const useUserStore = defineStore('user', { state: () => { return { userName: 'lucio', userId: '001', userData: null, } }, getters: { // ... }, actions: { async loginAndGetUserInfo(password) { try { this.userData = await api.login({password}); showToast('Login success'); } catch(error) { showToast(error); return error; } } } })
可以使用 store.$onAction()
訂閱 action 及其結果。
下面對userStore
新增一個訂閱,記錄上面的登陸操作,所用的時間
const unsubscribe = userStore.$onAction( ({ name, // action 的名字 store, // store 範例 args, // 呼叫這個 action 的引數 after, // 在這個 action 執行完畢之後,執行這個函數 onError, // 在這個 action 丟擲異常的時候,執行這個函數 }) => { // 記錄開始的時間變數 const startTime = Date.now() // 這將在 `store` 上的操作執行之前觸發 console.log(`Start "${name}" with params [${args.join(', ')}].`) // 如果 action 成功並且完全執行後,after 將觸發。 // 它將等待任何返回的 promise after((result) => { console.log( `Finished "${name}" after ${ Date.now() - startTime }ms.nResult: ${result}.` ) }) // 如果 action 丟擲或返回 Promise.reject ,onError 將觸發 onError((error) => { console.warn( `Failed "${name}" after ${Date.now() - startTime}ms.nError: ${error}.` ) }) } ) // 手動移除訂閱 unsubscribe()
和訂閱state一樣,元件解除安裝時,訂閱將被刪除,可以新增設定第二個引數detach
為true,在解除安裝元件後仍然保留訂閱。
export default { setup() { const someStore = useSomeStore() // 此訂閱將在元件解除安裝後保留 someStore.$onAction(callback, true) // ... }, }
到此這篇關於Pinia入門學習之實現簡單的使用者狀態管理的文章就介紹到這了,更多相關Pinia使用者狀態管理內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45