《Vue3 基础知识》Pinia 02 之 项目中从 Vuex 转 Pinia

2024-06-11 23:04

本文主要是介绍《Vue3 基础知识》Pinia 02 之 项目中从 Vuex 转 Pinia,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Vuex 转 Pinia

前言

想了解基础知识可移步《《Vue3 基础知识》Pinia 01 之 基础》

Vue3 项目中增 Pinia,且能与 Vuex4 同时使用。

安装

npm i pinia

文件目录

  • 新建文件夹 stores,注意是复数 s。因为 Pinia 中每个模块都是一个 store;
  • 文件 index.jsPinia 初始化文件。其它文件是带 id 的单个 store
# Pinia 目录结构,注意 ID 与文件名匹配
src
└── stores├── index.js          # 初始化 Pinia├── gmThemePro.js     # 'gmThemePro' id└── user.js           # 'user' id

初始化

src/stores/index.js 中初始化 Pinia

import { createPinia } from 'pinia'const pinia = createPinia()export default pinia;

src/main.js 中注册,更多单页面应用在此;

import { createApp } from 'vue'
import App from './App.vue'
import pinia from './stores' // 导入 /stores/index.js// 创建 Vue 实例
const app = createApp(App)// 注册,注意任何 useXxxStore 都得在此代码之后使用
app.use(pinia)

改造

src\store\modules\user.js 为例,改造为 src\stores\user.js

  • 使用 defineStore 定义一个 store,且唯一 iduser。;
  • state 转换为一个箭头函数;
  • getter 中的第一个参数 state 删除,所有东西都可用 this 访问;
  • actions 中的第一个参数 context 删除,所有东西都可用 this 访问;
  • mutationsPinia 中被弃用,可转为 action,将第一个参数 state 删除,所有东西都可用 this 访问;
import { defineStore } from 'pinia'// 常量名建议以 `use` 开头且以 `Store` 结尾
export const useUserStore = defineStore('user', {state: () => {return {avatar: '',name: '',isManager: false,adminIds: [], //后台管理权限}},actions: {// 登录login(obj) {// TODO},// 登出logout() {// TODO},// 设置用户信息,原 mutations 中的 SET_NAMEsetUserInfo( userName, isManager, userInfoRole) {// TODO},// 设置权限信息,原 mutations 中的 SET_PRIVILEGEsetPrivilege(obj) {this.adminIds = obj.privilegeExts}}
})

使用

  • 代码第 3 行,先引入 sotre
  • 代码第 9 行,再初始化 sotre
  • 代码第 15,19 行,state/getters/actions 都可用 this.userStore 直接访问;
<script>
<!-- 第一步: 引入 --> 
import { useUserStore } from '@/stores/user'<!-- 第二步: 定义为计算属性 -->
export default {computed: {userStore() {return useUserStore();},},methods: {getUserName() {// 直接调属性 namereturn this.userStore.name;},logout() {// 直接调方法 logoutthis.userStore.logout();}}
</script>

这篇关于《Vue3 基础知识》Pinia 02 之 项目中从 Vuex 转 Pinia的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1052498

相关文章

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

springboot项目打jar制作成镜像并指定配置文件位置方式

《springboot项目打jar制作成镜像并指定配置文件位置方式》:本文主要介绍springboot项目打jar制作成镜像并指定配置文件位置方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录一、上传jar到服务器二、编写dockerfile三、新建对应配置文件所存放的数据卷目录四、将配置文

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)

怎么用idea创建一个SpringBoot项目

《怎么用idea创建一个SpringBoot项目》本文介绍了在IDEA中创建SpringBoot项目的步骤,包括环境准备(JDK1.8+、Maven3.2.5+)、使用SpringInitializr... 目录如何在idea中创建一个SpringBoot项目环境准备1.1打开IDEA,点击New新建一个项

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

HTML input 标签示例详解

《HTMLinput标签示例详解》input标签主要用于接收用户的输入,随type属性值的不同,变换其具体功能,本文通过实例图文并茂的形式给大家介绍HTMLinput标签,感兴趣的朋友一... 目录通用属性输入框单行文本输入框 text密码输入框 password数字输入框 number电子邮件输入编程框

HTML img标签和超链接标签详细介绍

《HTMLimg标签和超链接标签详细介绍》:本文主要介绍了HTML中img标签的使用,包括src属性(指定图片路径)、相对/绝对路径区别、alt替代文本、title提示、宽高控制及边框设置等,详细内容请阅读本文,希望能对你有所帮助... 目录img 标签src 属性alt 属性title 属性width/h

CSS3打造的现代交互式登录界面详细实现过程

《CSS3打造的现代交互式登录界面详细实现过程》本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋... 目录1. css3用户登录界面设计概述1.1 用户界面设计的重要性1.2 CSS3的新特性与优势1.

HTML5 中的<button>标签用法和特征

《HTML5中的<button>标签用法和特征》在HTML5中,button标签用于定义一个可点击的按钮,它是创建交互式网页的重要元素之一,本文将深入解析HTML5中的button标签,详细介绍其属... 目录引言<button> 标签的基本用法<button> 标签的属性typevaluedisabled