iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >Vue使用pinia管理数据pinia持久化存储问题
  • 240
分享到

Vue使用pinia管理数据pinia持久化存储问题

Vuepinia管理数据pinia持久化存储pinia管理数据 2023-03-24 11:03:02 240人浏览 薄情痞子
摘要

目录Vue使用pinia管理数据vue3 + TSTS 类型声明文件AxiOS 二次封装pinia 持久化存储用法常见疑问进阶用法(按需持久化所需数据)总结Vue使用pinia管理数

Vue使用pinia管理数据

Vue3 + TS

步骤:

main.ts中注册 pinia

import { createPinia } from 'pinia'

const pinia = createPinia()

app.use(pinia)

创建文件store/modules/home.ts,用于管理home模块的数据

import { defineStore } from 'pinia'

const useHomeStore = defineStore('home',{
    state:()=>({
        name:'tony'
    })
})

export default useHomeStore

创建store/index.ts统一管理所有的模块

import useHomeStore from './modules/home'

const useStore = () => {
    return {
        home:useHomeStore()
    }
}

export default useStore

测试

import useStore from '@/store'
const { home } = useStore()
console.log(home.tony)

实际操作:使用 Pinia 获取头部分类导航

store/modules/home.ts中提供 state 和 actions

const useHomeStore = defineStore('home',{
    state:() =>({
        cateGoryList:[]
    }),
    actions:{
     aysnc getAllCategory(){
      const {data} = await rquest.get('/home/category/head')
      this.categoryList = data.result                        
     }
    }
})

Layout/index.vue中发送请求

<script setup lang="ts">
import useStore from '@/store'
const { home } = useStore()
home.getAllCategory()
</script>

TS 类型声明文件

定义类型声明

src\types\api\home.d.ts中定义数据类型

// 分类数据单项类型
export interface Goods {
  desc: string;
  id: string;
  name: string;
  picture: string;
  price: string;
  title: string;
  alt: string;
};

export interface Children {
  id: string;
  name: string;
  picture: string;
  goods: Goods[];
};

export interface Category {
  id: string;
  name: string;
  picture: string;
  children: Children[];
  goods: Goods[];
};

// 分类数据列表类型
export type CategoryList = Category[];

类型出口统一

新建 src\types\index.d.ts

// 统一导出所有类型文件
export * from "./api/home";

应用

修改store/modules/home.ts,给 axios 请求增加泛型

import { defineStore } from "pinia";
import request from "@/utils/request";
import type { CategoryList } from "@/types";

const useHomeStore = defineStore("home", {
  state: () => ({
    categoryList: [] as CategoryList,
  }),
  actions: {
    async getAllCategory() {
      const {data} = await request.get("/home/category/head");
      this.categoryList = data.result;
    },
  },
});

export default useHomeStore;

Axios 二次封装

src\utils\request.ts

-import axios from "axios";
+import axios, { type Method } from "axios";

const instance = axios.create({
  baseURL: "xxx",
  timeout: 5000,
});

// 添加请求拦截器
instance.interceptors.request.use(
  function (config) {
    // 在发送请求之前做些什么
    return config;
  },
  function (error) {
    // 对请求错误做些什么
    return Promise.reject(error);
  }
);

// 添加响应拦截器
instance.interceptors.response.use(
  function (response) {
    return response;
  },
  function (error) {
    // 对响应错误做点什么
    return Promise.reject(error);
  }
);

+ // 后端返回的接口数据格式
+ interface ApiRes<T = unknown> {
+    msg: string;
+    result: T;
+ }

+
+export const Http = <T>(method: Method, url: string, submitData?: object) => {
+  return instance.request<ApiRes<T>>({
+    url,
+    method,
+    // ? 自动设置合适的 params/data 键名称,如果 method 为 get 用 params 传请求参数,否则用 data
+    [method.toUpperCase() === "GET" ? "params" : "data"]: submitData,
+  });
+};

export default instance;

使用store/modules/home.ts

import { defineStore } from 'pinia'
-import request from "@/utils/request";
+import { http } from "@/utils/request";

const useHomeStore = defineStore('home',{
    state:()=>({
        name:'tony'
    }),
    actions: {
    async getAllCategory() {
-    const res = await request.get<ApiRes<CategoryList>>("/home/category/head");
+    // 使用起来简洁很多
+    const res = await http<CategoryList>("GET", "/home/category/head");
     this.categoryList = res.data.result;
    },
  },
})

export default useHomeStore

pinia 持久化存储

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

插件文档:点击查看

用法

安装

yarn add pinia-plugin-persistedstate
# 或
npm i pinia-plugin-persistedstate

使用插件

import piniaPluginPersistedstate from 'pinia-plugin-persistedstate'

const pinia = createPinia();
pinia.use(piniaPluginPersistedstate);
app.use(pinia);

模块开启持久化

const useHomeStore = defineStore("home",()=>{
...
},
// defineStore 第三个参数
  {
    // 添加配置开启 state/ref 持久化存储
    // 插件默认存储全部 state/ref
    persist: true,
  }
);

常见疑问

Vue2 能不能用 Pinia 和 持久化存储插件。

  • 可以使用,需配合 @vue/composition-api 先让 Vue2 老项目支持 组合式API。
  • Pinia 能在 组合式API 中使用。

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

  • 先读取本地的数据,如果新的请求获取到新数据,会自动把新数据覆盖掉旧的数据。
  • 无需额外处理,插件会自己更新到最新数据。

进阶用法(按需持久化所需数据)

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

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

import { defineStore } from 'pinia'

export const useStore = defineStore('main', {
  state: () => {
    return {
      someState: 'hello pinia',
      nested: {
        data: 'nested pinia',
      },
    }
  },
  // 所有数据持久化
  // persist: true,
  // 持久化存储插件其他配置
  persist: {
    // 按需存储 state/ref
    // 修改存储中使用的键名称,默认为当前 Store的 id
    key: 'storekey',
    // 修改为 sessionStorage,默认为 localStorage
    storage: window.sessionStorage,
    // ?按需持久化,默认不写会存储全部
    paths: ['nested.data'],
  },
})

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: Vue使用pinia管理数据pinia持久化存储问题

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

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

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

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

下载Word文档
猜你喜欢
  • Vue使用pinia管理数据pinia持久化存储问题
    目录Vue使用pinia管理数据Vue3 + TSTS 类型声明文件Axios 二次封装pinia 持久化存储用法常见疑问进阶用法(按需持久化所需数据)总结Vue使用pinia管理数...
    99+
    2023-03-24
    Vue pinia管理数据 pinia持久化存储 pinia管理数据
  • Vue怎么使用pinia管理数据
    这篇文章主要讲解了“Vue怎么使用pinia管理数据”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue怎么使用pinia管理数据”吧!Vue使用pinia管理数据Vue3 + TS步骤:在...
    99+
    2023-07-05
  • Pinia简单使用及数据持久化怎么实现
    这篇文章主要讲解了“Pinia简单使用及数据持久化怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Pinia简单使用及数据持久化怎么实现”吧!基本介绍Pinia 是 Vue.js 的轻...
    99+
    2023-06-30
  • Pinia简单使用以及数据持久化详解
    目录基本介绍基本使用与stateactions的使用getters的使用storeToRefs的使用pinia模块化pinia数据持久化用法常见疑问进阶用法总结基本介绍 Pinia ...
    99+
    2024-04-02
  • Kubernetes存储系统数据持久化管理方法是什么
    本篇内容主要讲解“Kubernetes存储系统数据持久化管理方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Kubernetes存储系统数据持久化管理方法是什么”吧!引言Kubernet...
    99+
    2023-07-04
  • 如何在Android开发中利用数据持久化存储文件
    这期内容当中小编将会给大家带来有关如何在Android开发中利用数据持久化存储文件,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。数据持久化数据持久化, 就是将内存中的瞬时数据保存在存储设备中, 保证即便关...
    99+
    2023-05-31
    android 数据持久化 roi
  • Qt使用SQLite数据库存储管理图片文件
    目录1、效果演示2、创建数据库及表格2.1 创建数据库2.2 创建数据库表格3、增删改查3.1 增加记录3.2 删除记录3.3 修改记录3.4 查找记录3.5 遍历表格记录1、效果演...
    99+
    2023-05-16
    Qt SQLite管理图片文件 Qt 管理图片文件 Qt SQLite
  • 如何使用ASP、大数据、Laravel、存储来优化企业的数据处理和存储?
    随着企业数据量的不断增加,如何优化数据处理和存储已经成为了企业管理的重要问题。本文将介绍如何使用ASP、大数据、Laravel和存储来解决这一问题。 ASP是一种非常流行的网络应用程序开发技术,它可以帮助企业快速开发出高效稳定的网络应用程...
    99+
    2023-11-12
    大数据 laravel 存储
  • 如何使用PHP处理大数据存储中的重定向问题?
    PHP是一种非常流行的服务器端编程语言,它可以用来处理大量的数据存储和处理任务。但是,当处理大量数据时,可能会遇到重定向问题,这可能会影响到整个应用程序的性能。在本文中,我们将探讨如何使用PHP来处理大数据存储中的重定向问题。 一、什么是重...
    99+
    2023-06-20
    大数据 存储 重定向
  • 如何使用Python解决大数据存储和分析问题?
    随着互联网的不断发展,数据量也在不断增长。对于数据科学家和分析师来说,处理大量数据已经成为日常工作。Python作为一种高效且易学的编程语言,成为了大数据存储和分析的首选工具。本文将介绍如何使用Python解决大数据存储和分析问题。 一、...
    99+
    2023-10-28
    http 大数据 自然语言处理
  • 如何使用Python和Git来优化数组的存储和管理?
    在数据分析和科学计算中,数组是最基本的数据结构之一,而Python和Git则是最常用的工具之一。在这篇文章中,我们将探讨如何使用Python和Git来优化数组的存储和管理。 一、Python中的数组 Python中的数组是一种列表(lis...
    99+
    2023-05-26
  • GO语言中如何使用UNIX存储函数来管理数据?
    在GO语言中,使用UNIX存储函数来管理数据是一种非常高效和可靠的方式。这些函数可以让我们轻松地与系统的文件和目录进行交互,同时还可以处理文件的元数据和权限设置。在本文中,我们将深入探讨如何使用UNIX存储函数来管理数据。 一、文件和目录...
    99+
    2023-07-23
    unix 存储 函数
  • Qt怎么使用SQLite数据库存储管理图片文件
    今天小编给大家分享一下Qt怎么使用SQLite数据库存储管理图片文件的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1、效果演...
    99+
    2023-07-06
  • 使用阿里云服务器对象存储进行数据管理
    阿里云服务器对象存储服务是阿里云提供的高效、稳定、安全的数据存储解决方案。它提供了海量的数据存储空间,可满足不同用户的数据存储需求。在本文中,我们将详细说明如何使用阿里云服务器对象存储服务进行数据管理。 一、阿里云服务器对象存储的基本概念阿...
    99+
    2023-12-15
    阿里 数据管理 对象
  • 如何在 PHP 中使用函数来优化大数据的存储和访问?
    在现代应用程序中,大数据处理已经成为了一项非常重要的任务。当我们需要处理大量数据时,我们需要考虑到如何优化数据的存储和访问。PHP 作为一种流行的服务器端脚本语言,提供了许多强大的函数和工具来处理大数据。本文将介绍如何在 PHP 中使用函数...
    99+
    2023-09-02
    大数据 函数 存储
  • java使用单向链表解决数据存储自定义排序问题
    目录表设计1. 新增一条记录2. 修改排序3. 删除代码实现1. 简单对象2. 对数据按照 nextId 排序3. 输出结果表设计 CREATE TABLE `test` ( `...
    99+
    2024-04-02
  • 如何使用ASP.NET Core在分布式环境中存储和管理NumPy数据?
    ASP.NET Core是一个跨平台的开源Web框架,它可以在分布式环境中存储和管理NumPy数据。NumPy是一个用于数值计算的Python库,它提供了高性能的多维数组和矩阵计算功能。在本文中,我们将探讨如何使用ASP.NET Core在...
    99+
    2023-10-02
    numy 存储 分布式
  • 如何使用Python实现容器同步存储,让数据管理更加简单?
    随着云计算技术的发展,越来越多的企业开始将应用程序部署在云平台上。而在云平台上,容器技术已经成为应用程序的主流部署方式。然而,容器的存储管理一直是一个难题。如何实现容器之间的数据共享和同步存储,一直是开发人员和运维人员面临的挑战。本文将介...
    99+
    2023-07-03
    容器 同步 存储
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作