我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

这篇文章主要讲解了“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简单使用及数据持久化怎么实现这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

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

下载Word文档

猜你喜欢

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

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

mysql怎么实现数据持久化

MySQL可以通过以下几种方式来实现数据持久化:使用磁盘存储:MySQL将数据存储在硬盘上,包括数据文件、日志文件等。这样即使服务器重启,数据也可以从硬盘上读取并恢复。使用数据库备份和恢复工具:MySQL提供了多种备份和恢复工具,如mysq
2023-10-21

mongodb数据持久化怎么实现

在MongoDB中,数据持久化是通过将数据写入硬盘来实现的。MongoDB会在后台自动将数据写入到磁盘中,以确保数据的持久性。MongoDB使用了一种称为WiredTiger的存储引擎,默认将数据持久化到磁盘。WiredTiger使用了一
2023-10-21

Vuex数据持久化怎么实现

小编给大家分享一下Vuex数据持久化怎么实现,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!什么是vuexvuex :是一个专为vue.js开发的状态管理器,采用集
2023-06-15

Redis怎么实现数据持久化

Redis 有两种数据持久化的方式:RDB持久化和AOF持久化。RDB持久化:RDB持久化是通过定期将内存中的数据快照写入磁盘来实现数据持久化的方式。可以通过配置文件中的save选项来设置保存快照的条件,比如save 900 1表示在90
Redis怎么实现数据持久化
2024-05-07

android数据持久化怎么实现

在Android中,有多种方式可以实现数据持久化,下面列举了几种常见的方法:1. Shared Preferences(共享首选项):用于存储简单的键值对数据,比如应用的设置项等。可以使用SharedPreferences类进行操作。2.
2023-10-21

使用PHP怎么实现数据库连接持久化

本篇文章给大家分享的是有关使用PHP怎么实现数据库连接持久化,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。PHP中的数据库连接持久化数据库的优化是我们做web开发的重中之重,甚
2023-06-15

mysql表数据持久化怎么实现

在MySQL中,数据持久化是通过将数据存储在磁盘上的表中来实现的。以下是一些实现数据持久化的方法:创建表:首先需要创建一个表来存储数据。可以使用MySQL的CREATE TABLE语句来创建一个新的表,指定表的名称和列的定义。插入数据:使用
2023-10-26

如何使用Redis实现数据持久化

如何使用Redis实现数据持久化引言Redis是一种快速、高效的内存数据库,但默认情况下它的数据是存储在内存中的。这就意味着一旦服务器断电或重启,Redis中的数据将会丢失。为了解决这个问题,Redis提供了一些机制来实现数据的持久化。本文
如何使用Redis实现数据持久化
2023-11-07

Couchbase中怎么实现数据持久化

在Couchbase中,数据持久化可以通过以下几种方式实现:使用持久化存储引擎:Couchbase支持使用不同的持久化存储引擎来保证数据的持久化,包括Couchbase自带的Magma存储引擎、ForestDB存储引擎以及可选的第三方存储引
Couchbase中怎么实现数据持久化
2024-03-08

Flask如何使用SQLAlchemy实现持久化数据

这篇文章主要介绍“Flask如何使用SQLAlchemy实现持久化数据”,在日常操作中,相信很多人在Flask如何使用SQLAlchemy实现持久化数据问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Flask
2023-06-20

Spark中怎么实现数据缓存和持久化

在Spark中,可以通过使用RDD的persist()方法来实现数据缓存。persist()方法有多种级别,包括MEMORY_ONLY、MEMORY_ONLY_SER、MEMORY_AND_DISK、MEMORY_AND_DISK_SER、
Spark中怎么实现数据缓存和持久化
2024-03-14

kubernetes数据持久化StorageClass动态供给怎么实现

这篇文章主要讲解了“kubernetes数据持久化StorageClass动态供给怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“kubernetes数据持久化StorageClass
2023-07-04

Spring Data JPA怎么实现持久化存储数据到数据库

这篇“Spring Data JPA怎么实现持久化存储数据到数据库”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Spring
2023-06-30

SpringBoot中怎么使用JPA作为数据持久化框架

今天小编给大家分享一下SpringBoot中怎么使用JPA作为数据持久化框架的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。J
2023-07-05

Spring+Redis集成怎么实现关系型数据库持久化

这篇文章主要讲解了“Spring+Redis集成怎么实现关系型数据库持久化”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Spring+Redis集成怎么实现关系型数据库持久化”吧!Redis
2023-06-03

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录