iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Pinia简单使用及数据持久化怎么实现
  • 700
分享到

Pinia简单使用及数据持久化怎么实现

2023-06-30 16:06:04 700人浏览 八月长安
摘要

这篇文章主要讲解了“Pinia简单使用及数据持久化怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Pinia简单使用及数据持久化怎么实现”吧!基本介绍Pinia 是 vue.js 的轻

这篇文章主要讲解了“Pinia简单使用及数据持久化怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Pinia简单使用及数据持久化怎么实现”吧!

基本介绍

Pinia 是 vue.js 的轻量级状态管理库

  • pinia和Vuex4一样,也是vue官方的状态管理工具(作者是 Vue 核心团队成员)

  • pinia相比vuex4,对于vue3的兼容性更好

  • pinia相比vuex4,具备完善的类型推荐

  • pinia同样支持vue开发者工具,最新的开发者工具对vuex4支持不好

pinia核心概念

  • state: 状态

  • actions: 修改状态(包括同步和异步,pinia中没有mutations)

  • getters: 计算属性

基本使用与state

目标:掌握pinia的使用步骤

(1)安装

yarn add pinia# ornpm i pinia

(2)在main.js中挂载pinia

import { createApp } from 'vue'import App from './App.vue'import { createPinia } from 'pinia'const pinia = createPinia()createApp(App).use(pinia).mount('#app')

(3)新建文件store/counter.js

import { defineStore } from 'pinia'// 创建store,命名规则: useXxxxStore// 参数1:store的唯一表示// 参数2:对象,可以提供state actions gettersconst useCounterStore = defineStore('counter', {  state: () => {    return {      count: 0,    }  },  getters: {     },  actions: {      },})export default useCounterStore

(4) 在组件中使用

<script setup>import useCounterStore from './store/counter'const counter = useCounterStore()</script><template>  <h2>根组件---{{ counter.count }}</h2></template><style></style>

actions的使用

目标:掌握pinia中actions的使用

在pinia中没有mutations,只有actions,不管是同步还是异步的代码,都可以在actions中完成。

(1)在actions中提供方法并且修改数据

import { defineStore } from 'pinia'// 1. 创建store// 参数1:store的唯一表示// 参数2:对象,可以提供state actions gettersconst useCounterStore = defineStore('counter', {  state: () => {    return {      count: 0,    }  },  actions: {    increment() {      this.count++    },    incrementAsync() {      setTimeout(() => {        this.count++      }, 1000)    },  },})export default useCounterStore

(2)在组件中使用

<script setup>import useCounterStore from './store/counter'const counter = useCounterStore()</script><template>  <h2>根组件---{{ counter.count }}</h2>  <button @click="counter.increment">加1</button>  <button @click="counter.incrementAsync">异步加1</button></template>

getters的使用

pinia中的getters和vuex中的基本是一样的,也带有缓存的功能

(1)在getters中提供计算属性

import { defineStore } from 'pinia'// 1. 创建store// 参数1:store的唯一表示// 参数2:对象,可以提供state actions gettersconst useCounterStore = defineStore('counter', {  state: () => {    return {      count: 0,    }  },  getters: {    double() {      return this.count * 2    },  },  actions: {    increment() {      this.count++    },    incrementAsync() {      setTimeout(() => {        this.count++      }, 1000)    },  },})export default useCounterStore

(2)在组件中使用

  <h2>根组件---{{ counter.count }}</h2>  <h4>{{ counter.double }}</h4>

storeToRefs的使用

目标:掌握storeToRefs的使用

如果直接从pinia中解构数据,会丢失响应式, 使用storeToRefs可以保证解构出来的数据也是响应式的

<script setup>import { storeToRefs } from 'pinia'import useCounterStore from './store/counter'const counter = useCounterStore()// 如果直接从pinia中解构数据,会丢失响应式const { count, double } = counter// 使用storeToRefs可以保证解构出来的数据也是响应式的const { count, double } = storeToRefs(counter)</script>

pinia模块化

在复杂项目中,不可能把多个模块的数据都定义到一个store中,一般来说会一个模块对应一个store,最后通过一个根store进行整合

(1)新建store/user.js文件

import { defineStore } from 'pinia'const useUserStore = defineStore('user', {  state: () => {    return {      name: 'zs',      age: 100,    }  },})export default useUserStore

(2)新建store/index.js

import useUserStore from './user'import useCounterStore from './counter'// 统一导出useStore方法export default function useStore() {  return {    user: useUserStore(),    counter: useCounterStore(),  }}

(3)在组件中使用

<script setup>import { storeToRefs } from 'pinia'import useStore from './store'const { counter } = useStore()// 使用storeToRefs可以保证解构出来的数据也是响应式的const { count, double } = storeToRefs(counter)</script>

pinia数据持久化

目标: 通过 Pinia 插件快速实现持久化存储。

插件文档:点击查看

用法

安装

yarn add pinia-plugin-persistedstateornpm i  pinia-plugin-persistedstate

使用插件 在main.ts中注册

import { createApp } from "vue";import App from "./App.vue";import piniaPluginPersistedstate from 'pinia-plugin-persistedstate'const pinia = createPinia();pinia.use(piniaPluginPersistedstate);createApp(App).use(pinia);

模块开启持久化

const useHomeStore = defineStore("home",{  // 开启数据持久化  persist: true  // ...省略});

常见疑问

  • 模块做了持久化后,以后数据会不会变,怎么办?

    • 先读取本地的数据,如果新的请求获取到新数据,会自动把新数据覆盖掉旧的数据。

    • 无需额外处理,插件会自己更新到最新数据。

进阶用法

需求:不想所有数据都持久化处理,能不能按需持久化所需数据,怎么办?

  • 可以用配置式写法,按需缓存某些模块的数据。

import { defineStore } from 'pinia'export const useStore = defineStore('main', s{  state: () => {    return {      someState: 'hello pinia',      nested: {        data: 'nested pinia',      },    }  },  // 所有数据持久化  // persist: true,  // 持久化存储插件其他配置  persist: {    // 修改存储中使用的键名称,默认为当前 Store的 id    key: 'storekey',    // 修改为 sessionStorage,默认为 localStorage    storage: window.sessionStorage,    // 部分持久化状态的点符号路径数组,[]意味着没有状态被持久化(默认为undefined,持久化整个状态)    paths: ['nested.data'],  },})

总结:相比于vuex,pinia对于typescript的支持性更好,友好的devTools支持,pinia只有1kb,简化了很多方法的写法。

感谢各位的阅读,以上就是“Pinia简单使用及数据持久化怎么实现”的内容了,经过本文的学习后,相信大家对Pinia简单使用及数据持久化怎么实现这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: Pinia简单使用及数据持久化怎么实现

本文链接: https://www.lsjlt.com/news/330426.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Pinia简单使用及数据持久化怎么实现
    这篇文章主要讲解了“Pinia简单使用及数据持久化怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Pinia简单使用及数据持久化怎么实现”吧!基本介绍Pinia 是 Vue.js 的轻...
    99+
    2023-06-30
  • Pinia简单使用以及数据持久化详解
    目录基本介绍基本使用与stateactions的使用getters的使用storeToRefs的使用pinia模块化pinia数据持久化用法常见疑问进阶用法总结基本介绍 Pinia ...
    99+
    2024-04-02
  • Vue使用pinia管理数据pinia持久化存储问题
    目录Vue使用pinia管理数据Vue3 + TSTS 类型声明文件Axios 二次封装pinia 持久化存储用法常见疑问进阶用法(按需持久化所需数据)总结Vue使用pinia管理数...
    99+
    2023-03-24
    Vue pinia管理数据 pinia持久化存储 pinia管理数据
  • Flask使用SQLAlchemy实现持久化数据
    目录项目引入flask-sqlalchemy ORM简介及模型定义 表关系类型及编码实现 一对多关系(多对一关系) 一对一关系 多对多关系 数据库基本操作 插入 更新 查询 删除 项...
    99+
    2024-04-02
  • Vuex数据持久化怎么实现
    小编给大家分享一下Vuex数据持久化怎么实现,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!什么是vuexvuex :是一个专为vue.js开发的状态管理器,采用集...
    99+
    2023-06-15
  • mongodb数据持久化怎么实现
    在MongoDB中,数据持久化是通过将数据写入硬盘来实现的。MongoDB会在后台自动将数据写入到磁盘中,以确保数据的持久性。 Mo...
    99+
    2023-10-21
    mongodb
  • mysql怎么实现数据持久化
    MySQL可以通过以下几种方式来实现数据持久化: 使用磁盘存储:MySQL将数据存储在硬盘上,包括数据文件、日志文件等。这样即使...
    99+
    2023-10-21
    mysql
  • Redis怎么实现数据持久化
    Redis 有两种数据持久化的方式:RDB持久化和AOF持久化。 RDB持久化: RDB持久化是通过定期将内存中的数据快照写入磁...
    99+
    2024-05-07
    Redis
  • android数据持久化怎么实现
    在Android中,有多种方式可以实现数据持久化,下面列举了几种常见的方法:1. Shared Preferences(共享首选项)...
    99+
    2023-10-21
    android
  • 使用PHP怎么实现数据库连接持久化
    本篇文章给大家分享的是有关使用PHP怎么实现数据库连接持久化,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。PHP中的数据库连接持久化数据库的优化是我们做web开发的重中之重,甚...
    99+
    2023-06-15
  • NoSQL数据库的简单介绍以及redis持久化数据服务
    本篇内容介绍了“NoSQL数据库的简单介绍以及redis持久化数据服务”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够...
    99+
    2024-04-02
  • 如何使用Redis实现数据持久化
    如何使用Redis实现数据持久化引言Redis是一种快速、高效的内存数据库,但默认情况下它的数据是存储在内存中的。这就意味着一旦服务器断电或重启,Redis中的数据将会丢失。为了解决这个问题,Redis提供了一些机制来实现数据的持久化。本文...
    99+
    2023-11-07
    数据 redis 持久化
  • mysql表数据持久化怎么实现
    在MySQL中,数据持久化是通过将数据存储在磁盘上的表中来实现的。以下是一些实现数据持久化的方法: 创建表:首先需要创建一个表来...
    99+
    2023-10-26
    mysql
  • Couchbase中怎么实现数据持久化
    在Couchbase中,数据持久化可以通过以下几种方式实现: 使用持久化存储引擎:Couchbase支持使用不同的持久化存储引擎...
    99+
    2024-03-08
    Couchbase
  • Flask如何使用SQLAlchemy实现持久化数据
    这篇文章主要介绍“Flask如何使用SQLAlchemy实现持久化数据”,在日常操作中,相信很多人在Flask如何使用SQLAlchemy实现持久化数据问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Flask...
    99+
    2023-06-20
  • ZooKeeper数据持久化是怎么实现的
    本篇内容介绍了“ZooKeeper数据持久化是怎么实现的”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、...
    99+
    2024-04-02
  • 0基础小白简单入门使用emqx的webhook+规则实现Mysql数据持久化
    EMQX (opens new window)是一款大规模可弹性伸缩的云原生分布式物联网 MQTT (opens new window)消息服务器。 作为全球最具扩展性的 MQTT 消息服务器,EMQX 提供了高效可靠海量物联网设备连接,能...
    99+
    2023-10-20
    服务器 数据库 运维 物联网 EMQX
  • docker如何实现数据持久化
    这篇文章主要为大家展示了“docker如何实现数据持久化”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“docker如何实现数据持久化”这篇文章吧。 docke...
    99+
    2024-04-02
  • Spark中怎么实现数据缓存和持久化
    在Spark中,可以通过使用RDD的persist()方法来实现数据缓存。persist()方法有多种级别,包括MEMORY_ONL...
    99+
    2024-03-14
    Spark
  • vuex持久化怎么实现
    本篇内容介绍了“vuex持久化怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!vuex持久化vuex:刷新浏览器,vuex中的stat...
    99+
    2023-06-22
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作