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

Vue狀態(tài)管理之使用Pinia代替Vuex

 更新時(shí)間:2021年11月08日 09:37:26   作者:rogepi  
這篇文章主要介紹了Vue狀態(tài)管理。下面文章主要圍繞著使用Pinia代替Vuex的相關(guān)資料展開具體內(nèi)容,需要的朋友可以參考一下,希望對(duì)你有所幫助

1、Pinia是什么

Pinia是一個(gè)vue的狀態(tài)管理方案,是vuex團(tuán)隊(duì)成員開發(fā),實(shí)現(xiàn)了很多vuex5的提案,更加地輕量化且有devtools的支持

vuex4一直被人詬病對(duì)于typescript的支持不良好,vuex5也遲遲未來

所以有了pinia的出現(xiàn)

相較于vuex:

  • pinia無需創(chuàng)建復(fù)雜的包裝器來支持typescript,對(duì)于typescript類型判斷是天然支持的,享受ide帶來的自動(dòng)補(bǔ)全,減少開發(fā)的心智負(fù)擔(dān),減少vue開發(fā)過程中的面向字符串編程
  • 減去了mutations的概念,只保留state,gettersanctions三個(gè)概念,減少代碼冗余
  • 無需手動(dòng)添加store,創(chuàng)建的store會(huì)在使用時(shí)自動(dòng)添加
  • 沒有模塊module的概念,不用面對(duì)一個(gè)store下嵌套著許多模塊,使用單文件store(有點(diǎn)類似redux/toolkit的一個(gè)reducer),可以直接導(dǎo)入其他store使用

Pinia文檔有這么一段話:

Pinia 試圖盡可能接近 Vuex 的理念。 它旨在測(cè)試 Vuex 下一次迭代的提案,并且取得了成功,因?yàn)槲覀兡壳坝幸粋€(gè)針對(duì) Vuex 5 的開放 RFC,其 API 與 Pinia 使用的 API 非常相似。 請(qǐng)注意,我(Eduardo),Pania 的作者,是 Vue.js 核心團(tuán)隊(duì)的一員,并積極參與了 Router 和 Vuex 等 API 的設(shè)計(jì)。 我個(gè)人對(duì)這個(gè)項(xiàng)目的意圖是重新設(shè)計(jì)使用全局 Store 的體驗(yàn),同時(shí)保持 Vue 平易近人的哲學(xué)。 我讓 Pania 的 API 與 Vuex 一樣接近,因?yàn)樗粩嘞蚯鞍l(fā)展,以便人們可以輕松地遷移到 Vuex 或什至在未來融合兩個(gè)項(xiàng)目(在 Vuex 下)。

所以現(xiàn)在學(xué)習(xí)Pinia,相當(dāng)于提前學(xué)習(xí)Vuex5就是說

2、Pinia簡(jiǎn)單上手

首先我們初始化一個(gè)vite+vue+ts工程

pnpm create vite pinia-demo -- --template vue-ts

安裝pinia

pnpm i pinia

打開項(xiàng)目,編輯src目錄下的mian.ts文件,引入Pinia

// main.ts
​
import { createApp } from 'vue'
import App from './App.vue'
​
import { createPinia } from 'pinia'
​
createApp(App).use(createPinia()).mount('#app')

src目錄下創(chuàng)建一個(gè)store文件夾用來存放狀態(tài)管理,然后新建一個(gè)counter.ts,我們來做一個(gè)簡(jiǎn)單的計(jì)數(shù)器狀態(tài)應(yīng)用

import { defineStore } from 'pinia'
​
export const useCounterStore = defineStore('counter', {
  state: () => {
    return {
      count: 0,
    }
  },
  getters: {
    doubleCount: (state) => state.count * 2,
  },
  actions: {
    increment() {
      this.count++
    },
  },
})

Pinia通過defineStore函數(shù)來創(chuàng)建一個(gè)store,它接收一個(gè)id用來標(biāo)識(shí)store,以及store選項(xiàng)

我們也可以使用一個(gè)回調(diào)函數(shù)來返回options,回調(diào)函數(shù)體內(nèi)的寫法類似vuesetup()寫法,比如上面的定義可以寫成

export const useCounterStore = defineStore('counter', () => {
  const count = ref(0)
  function doubleCount() {
    return count.value * 2
  }
  function increment() {
    count.value++
  }
​
  return { count, increment }
})

接著我們?cè)?code>App.vue中使用store

<script setup lang="ts">
import { useCounterStore } from './store/counter'
const useCounter = useCounterStore()
</script>
​
<template>
  <h2>{{ useCounter }}</h2>
  <h2>{{ useCounter.count }}</h2>
  <h2>{{ useCounter.doubleCount() }}</h2>
  <button @click="useCounter.increment">increment</button>
</template>
​
<style>
#app {
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>

在使用Pinia的過程中可以發(fā)現(xiàn)自動(dòng)補(bǔ)全是相當(dāng)優(yōu)秀

瀏覽器運(yùn)行如下:

打開開發(fā)者工具查看vue devtool

vue devtool支持對(duì)Pinia狀態(tài)的增刪改查!

Pinia有多種對(duì)狀態(tài)的修改方式:

  • 使用actions,如上面所示
  • 直接在狀態(tài)上修改
const countPlus_1 = useCounter.count++

使用store$patch函數(shù),支持選項(xiàng)和回調(diào)函數(shù)兩種寫法,回調(diào)函數(shù)適用于狀態(tài)為數(shù)組或其他之類的需要調(diào)用狀態(tài)方法進(jìn)行修改

const countPlus_2 = useCounter.$patch({ count: useCounter.count + 1 })

const countPlus_3 = useCounter.$patch((state) => state.count++)

對(duì)狀態(tài)的結(jié)構(gòu)需要使用StoreToRefs函數(shù)

const { count } = storeToRefs(useCounter)

3、使用體驗(yàn)

Pinia的學(xué)習(xí)和使用是相當(dāng)友好的,看一遍官方文檔就能上手,在上手過程中可以明顯地感受到相對(duì)于vuex更加快捷,編碼體驗(yàn)優(yōu)秀。

狀態(tài)管理對(duì)于小項(xiàng)目來說更注重于方便和快捷(甚至可以不想需要),所以像vuex是稍微有些復(fù)雜了,像vue3出beta的時(shí)候就有人說可以使用組合式api比如provideinject配合來替代vuex,所以Pinia這個(gè)輕量級(jí)狀態(tài)管理方案的出現(xiàn)是相當(dāng)及時(shí)的。

到此這篇關(guān)于Vue狀態(tài)管理之使用Pinia代替Vuex的文章就介紹到這了,更多相關(guān)使用Pinia代替Vuex內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解如何使用webpack打包Vue工程

    詳解如何使用webpack打包Vue工程

    本篇文章主要介紹了詳解如何使用webpack打包Vue工程,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-05-05
  • 解決echarts圖表使用v-show控制圖表顯示不全的問題

    解決echarts圖表使用v-show控制圖表顯示不全的問題

    這篇文章主要介紹了解決echarts圖表使用v-show控制圖表顯示不全的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • 解決Vue 項(xiàng)目打包后favicon無法正常顯示的問題

    解決Vue 項(xiàng)目打包后favicon無法正常顯示的問題

    今天小編就為大家分享一篇解決Vue 項(xiàng)目打包后favicon無法正常顯示的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • Nuxt.js SSR與權(quán)限驗(yàn)證的實(shí)現(xiàn)

    Nuxt.js SSR與權(quán)限驗(yàn)證的實(shí)現(xiàn)

    這篇文章主要介紹了Nuxt.js SSR與權(quán)限驗(yàn)證的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-11-11
  • Vue高性能列表GridList組件及實(shí)現(xiàn)思路詳解

    Vue高性能列表GridList組件及實(shí)現(xiàn)思路詳解

    這篇文章主要為大家介紹了Vue高性能列表GridList組件及實(shí)現(xiàn)思路詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-11-11
  • Vue實(shí)現(xiàn)進(jìn)度條變化效果

    Vue實(shí)現(xiàn)進(jìn)度條變化效果

    這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)進(jìn)度條變化效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • vue實(shí)現(xiàn)登錄時(shí)滑塊驗(yàn)證

    vue實(shí)現(xiàn)登錄時(shí)滑塊驗(yàn)證

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)登錄時(shí)滑塊驗(yàn)證,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Vue.js實(shí)現(xiàn)的計(jì)算器功能完整示例

    Vue.js實(shí)現(xiàn)的計(jì)算器功能完整示例

    這篇文章主要介紹了Vue.js實(shí)現(xiàn)的計(jì)算器功能,結(jié)合完整實(shí)例形式分析了vue.js響應(yīng)鼠標(biāo)事件實(shí)現(xiàn)基本的數(shù)值運(yùn)算相關(guān)操作技巧,可實(shí)現(xiàn)四則運(yùn)算及乘方、開方等功能,需要的朋友可以參考下
    2018-07-07
  • Vue-CLI 3.X 部署項(xiàng)目至生產(chǎn)服務(wù)器的方法

    Vue-CLI 3.X 部署項(xiàng)目至生產(chǎn)服務(wù)器的方法

    這篇文章主要介紹了Vue-CLI 3.X 部署項(xiàng)目至生產(chǎn)服務(wù)器的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • vant的picker的坑及解決

    vant的picker的坑及解決

    這篇文章主要介紹了vant的picker的坑及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12

最新評(píng)論