Vue3 Pinia的创建与使用代替Vuex 全局数据共享 同步异步
创始人
2024-11-19 09:07:21
0

介绍

提供跨组件和页面的共享状态能力,作为Vuex的替代品,专为Vue3设计的状态管理库。

  • Vuex:在Vuex中,更改状态必须通过Mutation或Action完成,手动触发更新。
  • Pinia:Pinia的状态是响应式的,当状态发生变化时,组件会自动更新,无需手动触发。

官方文档 :https://pinia.vuejs.org/zh/getting-started.html

使用Pinia对用户的登录信息进行保存

安装

npm install pinia 

引入

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

定义Stroe

目录结构:src/store/user.js

import  {defineStore} from  'pinia' import {reactive, ref} from "vue"; //导入pinia  //user表示模块名 export const useUser =defineStore('user',()=>{      //定义数据(state)d     const userId=ref(6699)     //用户ID     const level =ref(10) //等级     const userMsg=reactive({         token:'addadgsadadadada',         phone:'13111111111',         age:13     })     //用户信息  	 const list =ref([])            //操作数据的函数(action 同步+异步)     const updateUser=(newUserId)=>{         userId.value=newUserId     } 	//修改账号信息      //数据返回出去 注:对象的形式     return{         userId,         updateUser,         userMsg     } }) 

读取Stroe

 
 

读取成功
在这里插入图片描述

修改Stroe

 

Action异步

Store

// src/store/user.js  const getList=async  ()=>{     const res =await axios.get('https://tools.mgtv100.com/external/v1/bank_names').then(r=>{         list.value=r.data.data     })  } 

组件

  
{{item.bank_name}}
onMounted(()=>{   getList() })  function getList(){   userStore.getList() } 

在这里插入图片描述


Getter计算

 

src/store/user.js

//getter     const cmpLevel=computed(()=>{         return level.value*2         //该函数用来计算等级     })  return {cmpLevel} // src/store/user.js 

在这里插入图片描述

相关内容

热门资讯

第九分钟揭幕!hhpoker德... 第九分钟揭幕!hhpoker德州牛仔视频(透视)都是存在有挂,德州教程(有挂功能)-哔哩哔哩1、让任...
五分钟开挂!哈糖大菠萝挂法(透... 五分钟开挂!哈糖大菠萝挂法(透视)竟然真的有挂,普及教程(有挂教学)-哔哩哔哩1、哈糖大菠萝挂法系统...
3分钟教你!hhpoker软件... 3分钟教你!hhpoker软件可以玩吗(透视)其实存在有挂,攻略方法(有挂功能)-哔哩哔哩1、超多福...
第2分钟了解!hhpoker辅... 第2分钟了解!hhpoker辅助挂下载(透视)本来真的有挂,分享教程(有挂实锤)-哔哩哔哩1、操作简...
七分钟透视!wepoker轻量... 七分钟透视!wepoker轻量版透视方法(透视)切实真的有挂,介绍教程(有挂细节)-哔哩哔哩wepo...
第三分钟详情!aapoker透... 第三分钟详情!aapoker透视插件(透视)切实真的是有挂,扑克教程(有挂功能)-哔哩哔哩1、aap...
八分钟开挂!aapoker破解... 八分钟开挂!aapoker破解侠是真的吗(透视)真是真的有挂,普及教程(讲解有挂)-哔哩哔哩1、起透...
1分钟专业!佛手在线大菠萝技巧... 您好,佛手在线大菠萝技巧这款游戏可以开挂的,确实是有挂的,需要了解加去威信【485275054】很多...
第一分钟专业!hh poker... 第一分钟专业!hh poker插件下载(透视)都是有挂,wpk教程(详细教程)-哔哩哔哩1、超多福利...
第二分钟解迷!拱趴大菠萝自动计... 第二分钟解迷!拱趴大菠萝自动计算机器人(透视)一直真的有挂,科技教程(有挂解惑)-哔哩哔哩1、拱趴大...