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

Vue狀態(tài)管理庫Pinia詳細介紹

 更新時間:2022年08月16日 11:13:45   作者:賢蛋大眼萌  
這篇文章主要介紹了Vue3-pinia狀態(tài)管理,pinia是 vue3 新的狀態(tài)管理工具,簡單來說相當于之前 vuex,它去掉了 Mutations 但是也是支持 vue2 的,需要的朋友可以參考下

什么是 Pinia

Pinia (西班牙語中的菠蘿),本質上依然是一個狀態(tài)管理的庫,用于跨組件、頁面進行狀態(tài)共享.

pinia 與 vuex 的區(qū)別:

  • 更友好的TypeScript支持,Vuex之前對TS的支持很不友好
  • 與 Vuex 相比,Pinia 提供了一個更簡單的 API,具有更少的儀式,提供了 Composition-API 風格的 API
  • 不再有modules的嵌套結構
  • 也不再有命名空間的概念,不需要記住它們的復雜關系

如何使用 Pinia

安裝 pinia

yarn add pinia

創(chuàng)建一個pinia

// src/stores/index.js
import { createPinia } from "pinia";
const pinia = createPinia()
export default pinia
//main.js
import pinia from './stores'
app.use(pinia)

認識 Store

一個 Store (如 Pinia)是一個實體,它會持有為綁定到你組件樹的狀態(tài)和業(yè)務邏輯,也就是保存了全局的狀態(tài)

這樣就可以定義任意數(shù)量的Store來管理你的狀態(tài),包括 state、getters、actions

定義一個store

  • Store 是使用 defineStore() 定義的,
  • 且它需要一個唯一名稱,作為第一個參數(shù)傳遞

使用 store

操作 State

state 是 store 的核心部分,store是用來實現(xiàn)我們管理狀態(tài)的。

  • 方式一:直接一個個修改state
  • 方式二:一次性修改多個狀態(tài)
  • 方式三:替換state
  • 方式四:重置state

Getters

1. 認識和定義 Getters

Getters相當于Store的計算屬性:

  • 可以用 defineStore() 中的 getters 屬性定義;
  • getters中可以定義接受一個state作為參數(shù)的函數(shù);

2. 訪問 Getters

  • 方式一:訪問當前 store 的Getters
  • 方式二:Getters 中訪問自己的其他Getters
  • 方式三:訪問其他的 store 的Getters
getters: {
    // 1. 基本使用
    debouleCount(state) {
      return state.count * 2
    },
    // 2. 一個 getters 引入另外一個 getters
    useDebouleCount() {
      return this.debouleCount + 2
    },
    // 3. getter也支持返回一個函數(shù)
    getFriendById(state) {
      return function (id) {
        for (let i = 0; i < state.vagetabel.length; i++) {
          const vagetabel = state.vagetabel[i]
          if (vagetabel.id === id) {
            return vagetabel
          }
        }
      }
    },
    // 4.訪問其他store中的Getters
    showMessage(state) {
      // 獲取user信息
      const useStore = useUser()
      // 獲取自己的state
      // 拼接信息
      return `name:${useStore.name} - count:${state.count}`
    }
  }

認識和定義 Action

Action 可以理解成組件中的 methods ,和getters一樣,在action中可以通過this訪問整個store實例的所有操作。

Action 是支持異步操作的,所以可以使用 await。

到此這篇關于Vue狀態(tài)管理庫Pinia詳細介紹的文章就介紹到這了,更多相關Vue Pinia內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • vue后臺管理添加多語言功能的實現(xiàn)示例

    vue后臺管理添加多語言功能的實現(xiàn)示例

    這篇文章主要介紹了vue后臺管理添加多語言功能的實現(xiàn)示例,幫助大家更好的理解和學習使用vue框架,感興趣的朋友可以了解下
    2021-04-04
  • 在Vue methods中調用filters里的過濾器實例

    在Vue methods中調用filters里的過濾器實例

    今天小編就為大家分享一篇在Vue methods中調用filters里的過濾器實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • Vue路由router詳解

    Vue路由router詳解

    這篇文章主要介紹了vue router 配置路由的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2021-10-10
  • VueJs 將接口用webpack代理到本地的方法

    VueJs 將接口用webpack代理到本地的方法

    本篇文章主要介紹了VueJs 將接口用webpack代理到本地的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • Ant?Design?of?Vue的樹形控件Tree的使用及說明

    Ant?Design?of?Vue的樹形控件Tree的使用及說明

    這篇文章主要介紹了Ant?Design?of?Vue的樹形控件Tree的使用及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • Vue關閉當前頁面的方法

    Vue關閉當前頁面的方法

    Vue中關閉當前頁面的方法與原生JavaScript類似,都是通過window對象的close方法實現(xiàn),這篇文章主要介紹了Vue關閉當前頁面的方法,需要的朋友可以參考下
    2023-09-09
  • Vue中實現(xiàn)權限控制的方法示例

    Vue中實現(xiàn)權限控制的方法示例

    這篇文章主要介紹了Vue中實現(xiàn)權限控制的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-06-06
  • vue項目打包上傳github并制作預覽鏈接(pages)

    vue項目打包上傳github并制作預覽鏈接(pages)

    這篇文章主要介紹了vue項目打包上傳github并制作預覽鏈接(pages)的相關資料,需要的朋友可以參考下
    2019-04-04
  • 解讀vue項目防范XSS攻擊問題

    解讀vue項目防范XSS攻擊問題

    這篇文章主要介紹了解讀vue項目防范XSS攻擊問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • Vue實現(xiàn)用戶自定義字段顯示數(shù)據(jù)的方法

    Vue實現(xiàn)用戶自定義字段顯示數(shù)據(jù)的方法

    今天小編就為大家分享一篇Vue實現(xiàn)用戶自定義字段顯示數(shù)據(jù)的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08

最新評論