成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

全新的 Vue3 狀態管理工具:Pinia

開發 前端
Vue3 發布已經有一段時間了,它采用了新的響應式系統,而且構建了一套全新的 Composition API。Vuex5 的提案,與 Pinia 實現的功能不能說毫無關系,只能說一模一樣,今天的文章就來給大家介紹一下這個菠蘿。

[[440717]]

Vue3 發布已經有一段時間了,它采用了新的響應式系統,而且構建了一套全新的 Composition API。Vue 的周邊生態都在加緊適配這套新的系統,官方的狀態管理庫 Vuex 也在適配中,為此官方提出了一個 Vuex 5 的全新提案。

  • 支持兩種語法創建 Store:Options Api 和 Composition Api;
  • 刪除 mutations,只支持 state、getters、actions;
  • 模塊化的設計,能很好支持代碼分割;
  • 沒有嵌套的模塊,只有 Store 的概念;
  • 完整的 TypeScript 支持;

在這個提案下方,有個評論很有意思。簡單翻譯一下:

好巧不巧,Vuex5 的提案,與 Pinia 實現的功能不能說毫無關系,只能說一模一樣,今天的文章就來給大家介紹一下這個菠蘿。

安裝

在現有項目中,用過如下命令進行 Pinia 模塊的安裝。

  1. # yarn 
  2. yarn add pinia@next 
  3. # npm 
  4. npm i pinia@next 

安裝完成后,需要在 Vue3 項目的入口文件中,進行導入安裝。

  1. // main.js 
  2. import { createApp } from 'vue' 
  3. import { createPinia } from 'pinia' 
  4. import App from './App.vue' 
  5.  
  6. // 實例化 Vue 
  7. const app = createApp(App) 
  8. // 安裝 Pinia 
  9. app.use(createPinia()) 
  10. // 掛載在真實 DOM 
  11. app.mount('#app'

上手

要使用 Pinia 的話,只需要定義一個 store,然后在用到該數據的地方進行導入。

定義 Store

  1. import { defineStore } from "pinia" 
  2.  
  3. // 對外部暴露一個 use 方法,該方法會導出我們定義的 state 
  4. const useCounterStore = defineStore({ 
  5.   // 每個 store 的 id 必須唯一 
  6.   id: 'counter'
  7.   // state 表示數據源 
  8.   state: () => ({ 
  9.     count: 0 
  10.   }), 
  11.   // getters 類似于 computed,可對 state 的值進行二次計算 
  12.   getters: { 
  13.     double () { 
  14.      // getter 中的 this 指向👉 state 
  15.      return this.count * 2 
  16.    }, 
  17.    // 如果使用箭頭函數會導致 this 指向有問題 
  18.    // 可以在函數的第一個參數中拿到 state 
  19.     double: (state) => { 
  20.      return state.count * 2 
  21.    } 
  22.   }, 
  23.   // actions 用來修改 state 
  24.   actions: { 
  25.     increment() { 
  26.       // action 中的 this 指向👉 state 
  27.       this.count++ 
  28.     }, 
  29.   } 
  30. }) 
  31.  
  32. export default useCounterStore 

除了使用上述類似 vuex 的方式來構建 state,還可以使用 function 的形式來創建 store,有點類似于 Vue3 中的 setup()。

  1. import { ref, computed } from "vue" 
  2. import { defineStore } from "pinia" 
  3.  
  4. // 對外部暴露一個 use 方法,該方法會導出我們定義的 state 
  5. const useCounterStore = defineStore('counter'function () { 
  6.   const count = ref(0) 
  7.   const double = computed(() => count.value * 2) 
  8.   function increment() { 
  9.     count.value++ 
  10.   } 
  11.   return { 
  12.    countdouble, increment 
  13.   } 
  14. }) 
  15.  
  16. export default useCounterStore 

使用 Store

前面也介紹過,Pinia 提供了兩種方式來使用 store,Options Api 和 Composition Api 中都完美支持。

Options Api

在 Options Api 中,可直接使用官方提供的 mapActions 和 mapState 方法,導出 store 中的 state、getter、action,其用法與 Vuex 基本一致,很容易上手。

  1. import { mapActions, mapState } from 'pinia' 
  2. import { useCounterStore } from '../model/counter' 
  3.  
  4. export default { 
  5.   name'HelloWorld'
  6.   computed: { 
  7.     ...mapState(useCounterStore, ['count''double']) 
  8.   }, 
  9.   methods: { 
  10.     ...mapActions(useCounterStore, ['increment']) 
  11.   } 

Composition Api

Composition Api 中,不管是 state 還是 getter 都需要通過 computed 方法來監聽變化,這和 Options Api 中,需要放到 computed 對象中的道理一樣。另外, Options Api 中拿到的 state 值是可以直接進行修改操作的,當然還是建議寫一個 action 來操作 state 值,方便后期維護。

  1. // Composition Api 
  2. import { computed } from 'vue' 
  3. import { useCounterStore } from '../stores/counter' 
  4. export default { 
  5.   name'HelloWorld'
  6.   setup() { 
  7.     const counter = useCounterStore() 
  8.     return { 
  9.       // state 和 getter 都需要在使用 computed,這和 Options Api 一樣 
  10.       count: computed(() => counter.count), 
  11.       double: computed(() => counter.double), 
  12.       increment: () => { counter.count++ }, // 可以直接修改 state 的值 
  13.       increment: counter.increment, // 可以引用 store 中定義的 action 
  14.     } 
  15.   } 

類型提示

在 Vuex 中,TypeScript 的類型提示做得不是很好,在進行類型推導時,只能找到它的 state。特別是寫代碼的過程中,代碼提示就很不智能。

而 pinia,就能推導出定義的所有 state、getter、action,這樣在寫代碼的時候,就會方便很多。

主要是 pinia 通過 TypeScript 進行了十分友好的類型定義,感興趣的可以看看 pinia 的類型定義文件(pinia.d.ts):

代碼分割

由于使用了模塊化設計,所有的 store 都能夠單獨引入,而不是像 vuex 一樣,通過 modules 的方式,將所有的 module 掛載到一個 store 上。

假設,我們當前通過 Vuex 創建了一個 Store,這個 Store 下有兩個 module,分別是用戶模塊(User)和商品模塊(Goods)。即使當前首頁只使用到了用戶信息,但是整個 Store 都會被打包到首頁的 js chunk 中。

如果我們使用 pinia,我們會使用 defineStore 定義兩個 完全是分離狀態的 store,兩個頁面在引入時,也互不影響。最后打包的時候,首頁的 js chunk 和商品頁的 js chunk 會分別打包對應的 store。

Pinia 的介紹到這里就告一段落了,如果現在有新項目要使用 Vue3 進行開發,推薦無腦使用 Pinia,更加簡潔,而且大小僅 1KB。

 

責任編輯:姜華 來源: 自然醒的筆記本
相關推薦

2024-12-20 09:12:00

Vue項目Pinia

2014-12-05 09:53:59

docker容器管理開源

2009-03-09 09:26:49

Informix數據庫管理OLTP

2024-04-08 07:28:27

PiniaVue3狀態管理庫

2024-03-01 11:32:22

Vue3APIVue.js

2024-04-02 08:50:08

Go語言react

2011-08-12 10:38:09

MongoDB

2024-05-10 08:38:01

JavaScriptPiniaVuex

2022-02-22 07:37:26

VuePinia態管理庫

2022-05-23 08:59:02

piniavue插件

2023-03-07 14:21:57

2010-05-25 18:36:54

MySQL管理工具

2011-04-13 16:21:22

SQL Server管理

2024-08-19 08:48:49

代碼渲染組件

2022-03-07 11:15:25

Pinia狀態庫vue3

2020-10-30 11:18:47

網絡技術工具

2020-09-30 14:05:22

網絡管理

2009-04-24 21:13:45

服務器虛擬化Vmware

2012-12-06 11:31:40

虛擬化

2012-04-09 09:43:49

云計算云管理
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 精品日韩在线 | 欧美不卡一区二区三区 | 精品日韩一区 | 国产婷婷色一区二区三区 | 久久久久一区二区 | 九九九国产| 欧美日韩亚洲一区 | 欧美综合国产精品久久丁香 | www.伊人.com | 久久精品综合 | 丝袜美腿一区二区三区动态图 | 天天草天天干天天 | 成人性生交a做片 | 欧美黄视频| 亚洲一区综合 | 日韩av在线一区二区 | 亚洲成人一区 | 久久性色 | 欧美综合一区二区三区 | 日本亚洲一区 | 日韩毛片| 国产精品久久久久永久免费观看 | 国产麻豆一区二区三区 | 免费的网站www | 黄色av网站在线免费观看 | 亚洲欧美一区二区三区国产精品 | 范冰冰一级做a爰片久久毛片 | 亚洲精品国产成人 | 亚洲国产一区二区三区 | 免费视频一区 | 国产成人99久久亚洲综合精品 | 国产精品久久久久久婷婷天堂 | 成人免费精品视频 | 久久影音先锋 | 国产日韩欧美中文字幕 | 男人的天堂中文字幕 | 人人精品 | yeyeav| 成人在线免费视频 | 国产视频线观看永久免费 | 国产在线一区二区三区 |