感受 Vue 新的状态管理工具之美之 Pinia---学习篇

简介: 感受 Vue 新的状态管理工具之美之 Pinia---学习篇

前言

     相信在Vue中提到状态管理,大家一定会想到 Vuex。的确 Vuex确实是比较强大的,但Vuex 多少有点重,而且对 Typescript的支持也不是那么的友好,同时门槛也比较高,学习成本比较大。

       基于以上种种原因,随着 Pinia 的不断完善 也渐渐的进入到小伙伴的视野中,今天就同大家一起学习一下 Pinia 的优美之处。

   Pinia 始于 2019年11月, 让人比较心动的事,Pinia 同时支持 Vue2 和 Vue3 这一点可以说是很良心的。当然,由于VueAdminWork中Vue3的版本比较多,我们下面只介绍一下在 Vue3 中的用法。

和 Vuex 差不多的事,Pinia 的 store 也同样有 `state`  `actions` `getters` 的这些概念,但比 Vuex 更加简洁的是没有 `mutations`,这一点个人觉得很赞。

4edc953e2c684bbe819ffa954c899c08.png

关于 pinia 打算分以下几个篇章讲一下

  • 学习篇
  • state篇
  • getters篇
  • actions篇
  • 持久化篇
  • 源码解析篇


基本概念

  • 引入并使用pinia

   引入

yarn add pinia
# or with npm
npm install pinia

   使用(Vue3中的用法)

import { createPinia } from 'pinia'
app.use(createPinia())
  • store

定义一个 store 很简单

import { defineStore } from 'pinia'
export const useStore = defineStore('main', {
  state: () => {
    return {}
  },
  actions: {},
  getters: {}
})

这里注意的是 第一个参数是必须要有的,并且是独一无二的,这将是一个 store 的唯一标识。

使用起来也比较方便

import { useStore } from '@/stores/counter'
export default {
  setup() {
    const store = useStore()
    return {
      store,
    }
  },
}
  • state

pinia 中的 state 也比较好理解,但有一点值得注意的是,state 需要是一个 函数 的类型,而且要返回一个 初始对象,这类似于Vue中 data() 方法。

import { defineStore } from 'pinia'
const useStore = defineStore('storeId', {
  state: () => {
    return {
      counter: 0,
      name: 'Eduardo',
      isAdmin: true,
    }
  },
})

访问 state中的属性,用法比较简单

const store = useStore()
store.counter++

重置 state

const store = useStore()
store.$reset()

和Vuex一样,pinia 同样也提供了 mapXXX 函数方便大家使用,在这里就不过多介绍了,感兴趣的同学可以去官网查看。

state 还有其它更加高级的用法,这篇文章先不介绍那么多了,下一篇具体看个例子介绍。


  • actions

按官网的介绍:actions 等于 组件中的 methods ,里面可以定义很多业务逻辑的方法。

export const useStore = defineStore('main', {
  state: () => ({
    counter: 0,
  }),
  actions: {
    increment() {
      this.counter++
    },
    randomizeCounter() {
      this.counter = Math.round(100 * Math.random())
    },
  },
})

但有一个地方非常点赞的是,actions里面的方法支持 异步。

actions: {
    async registerUser(login, password) {
      try {
        this.userData = await api.post({ login, password })
        showTooltip(`Welcome back ${this.userData.name}!`)
      } catch (error) {
        showTooltip(error)
        // let the form component display the error
        return error
      }
    },
  }

使用起来也比较方便

export default defineComponent({
  setup() {
    const main = useMainStore()
    main.randomizeCounter()
    return {}
  },
})
  • getters

getters 等于 组件中  computed ,用法也很简单

export const useStore = defineStore('main', {
  state: () => ({
    counter: 0,
  }),
  getters: {
    doubleCount: (state) => state.counter * 2,
  },
})

用起来和 computed 里面的属性一样:

<template>
  <p>Double count is {{ store.doubleCount }}</p>
</template>
<script>
export default {
  setup() {
    const store = useStore()
    return { store }
  },
}
</script>

以上便是对 pinia 的几个重要概念简单介绍,比较简单,大家先入门,后面我们一步步认识 pinia

相关文章
|
1天前
|
资源调度 JavaScript 前端开发
Vue Router 的使用方式是什么
【8月更文挑战第30天】Vue Router 的使用方式是什么
8 2
|
1天前
|
JavaScript 前端开发 测试技术
Vue.js开发者必看!Vue Test Utils携手端到端测试,打造无懈可击的应用体验,引领前端测试新风尚!
【8月更文挑战第30天】随着Vue.js的普及,构建可靠的Vue应用至关重要。测试不仅能确保应用质量,还能提升开发效率。Vue Test Utils作为官方测试库,方便进行单元测试,而结合端到端(E2E)测试,则能构建全面的测试体系,保障应用稳定性。本文将带你深入了解如何使用Vue Test Utils进行单元测试,通过具体示例展示如何测试组件行为;并通过Cypress进行E2E测试,确保整个应用流程的正确性。无论是单元测试还是E2E测试,都能显著提高Vue应用的质量,让你更加自信地交付高质量的应用。
|
1天前
|
存储 JavaScript 前端开发
Vue.js + Vuex:解锁前端复杂应用的神秘钥匙,探索状态管理的新境界!
【8月更文挑战第30天】Vue.js结合Vuex状态管理,为复杂前端应用提供了解锁高效与优雅的金钥匙。Vue.js凭借简洁的API和高效虚拟DOM更新机制广受好评,但在大规模应用中,组件间状态共享变得复杂。这时,Vuex通过中心化状态存储,使状态管理清晰可见,如同为Vue.js应用增添智慧大脑。例如,在购物车应用中,Vuex通过`state`、`mutations`、`actions`和`getters`清晰管理状态,简化组件间状态同步,减少耦合,确保单一状态源,使开发更加高效有序。在Vue.js的世界里,Vuex是一位智慧管家,让前端开发不仅高效,更成为一门艺术。
|
1天前
|
JavaScript 前端开发 UED
揭秘Vue.js高效开发:Vue Router如何让单页面应用路由管理变得如此简单?
【8月更文挑战第30天】随着Web应用复杂性的增加,单页面应用(SPA)因出色的用户体验和高效的页面加载性能而备受青睐。Vue.js凭借简洁的语法和灵活的组件系统成为构建SPA的热门选择,其官方路由管理器Vue Router则简化了路由管理。本文通过实战示例介绍如何利用Vue Router实现高效的SPA路由管理,包括命名路由、动态路由及其核心优势。
5分钟上手Vue+ts+vite+pinia
5分钟上手Vue+ts+vite+pinia
696 0
|
4天前
|
存储 JavaScript 前端开发
Vue应用瘦身秘籍:揭秘Vuex如何重塑你的应用状态,让复杂变简单!🔥
【8月更文挑战第27天】在开发Vue应用时,随着应用规模的增长,组件间通信与状态共享问题日益复杂。Vuex作为Vue官方推荐的状态管理库,提供了集中式存储仓库来管理组件的共享状态,简化状态跟踪与组件通信。Vuex的核心概念包括state(存储状态数据)、mutations(同步修改state)和actions(处理异步操作)。通过一个购物车应用示例展示了如何定义state、mutations及actions,以及如何在Vue组件中使用这些状态管理功能。掌握Vuex有助于提高应用的健壮性和可维护性。
29 0
|
4天前
|
存储 JavaScript
解锁Vuex高级玩法:模块化与插件共舞,让你的Vue项目状态管理如虎添翼!
【8月更文挑战第27天】Vuex是一款专为Vue.js应用程序设计的状态管理模式及库,它通过集中管理组件状态来确保状态变更的可预测性。在大型应用中,采用模块化管理可以让代码结构更加清晰,同时利用插件增强功能。模块化管理允许将store拆分为包含各自state、mutations、actions和getters的独立模块。插件则能监听状态变化,实现诸如日志记录或数据持久化等功能。本文通过具体示例介绍了如何在Vuex中实现模块化管理和插件的高级应用。
15 1
|
2天前
|
JavaScript 开发者
[译] 监听第三方 Vue 组件的生命周期钩子
[译] 监听第三方 Vue 组件的生命周期钩子
|
2天前
|
JavaScript 前端开发
[译] 复用 Vue 组件的 6 层手段
[译] 复用 Vue 组件的 6 层手段
|
3天前
|
JavaScript 开发者
vue学习之响应式数据绑定
响应式数据绑定
11 0
下一篇
云函数