《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

相关文章

springboot项目如何开启https服务

《springboot项目如何开启https服务》:本文主要介绍springboot项目如何开启https服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录springboot项目开启https服务1. 生成SSL证书密钥库使用keytool生成自签名证书将

HTML5中的Microdata与历史记录管理详解

《HTML5中的Microdata与历史记录管理详解》Microdata作为HTML5新增的一个特性,它允许开发者在HTML文档中添加更多的语义信息,以便于搜索引擎和浏览器更好地理解页面内容,本文将探... 目录html5中的Mijscrodata与历史记录管理背景简介html5中的Microdata使用M

html5的响应式布局的方法示例详解

《html5的响应式布局的方法示例详解》:本文主要介绍了HTML5中使用媒体查询和Flexbox进行响应式布局的方法,简要介绍了CSSGrid布局的基础知识和如何实现自动换行的网格布局,详细内容请阅读本文,希望能对你有所帮助... 一 使用媒体查询响应式布局        使用的参数@media这是常用的

HTML5表格语法格式详解

《HTML5表格语法格式详解》在HTML语法中,表格主要通过table、tr和td3个标签构成,本文通过实例代码讲解HTML5表格语法格式,感兴趣的朋友一起看看吧... 目录一、表格1.表格语法格式2.表格属性 3.例子二、不规则表格1.跨行2.跨列3.例子一、表格在html语法中,表格主要通过< tab

将Java项目提交到云服务器的流程步骤

《将Java项目提交到云服务器的流程步骤》所谓将项目提交到云服务器即将你的项目打成一个jar包然后提交到云服务器即可,因此我们需要准备服务器环境为:Linux+JDK+MariDB(MySQL)+Gi... 目录1. 安装 jdk1.1 查看 jdk 版本1.2 下载 jdk2. 安装 mariadb(my

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

前端CSS Grid 布局示例详解

《前端CSSGrid布局示例详解》CSSGrid是一种二维布局系统,可以同时控制行和列,相比Flex(一维布局),更适合用在整体页面布局或复杂模块结构中,:本文主要介绍前端CSSGri... 目录css Grid 布局详解(通俗易懂版)一、概述二、基础概念三、创建 Grid 容器四、定义网格行和列五、设置行

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll