当前位置:首页 » 《资源分享》 » 正文

Pinia 使用方法,配合localStorage实现存储用户信息

13 人参与  2024年09月30日 08:00  分类 : 《资源分享》  评论

点击全文阅读


什么是 Pinia

Pinia 是 Vue.js 应用程序的一个现代化的状态管理库,它用于集中管理和共享组件之间的数据,state、getter、和 action 是构建状态管理的核心概念,它们分别对应数据存储、计算属性和操作方法。

使用方法

安装

npm install pinia

main.js引入

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

创建文件

在 src 文件中,创建 store 文件,里面按模块创建js文件

store/user.js

import { defineStore } from 'pinia'import { ref } from 'vue'export const useUserStore = defineStore('userInfo', {        // 类似于data        state: () => {            return {                userInfo: null            }        },        // 类似于methods        actions: {            setUserInfo(userInfo){                this.userInfo = userInfo            }        }    })

使用

由于我想使用pinia实现用户登录信息的管理,并使用localStorage实现持久化存储。

login.vue

<script>    import background from '../assets/img/background-0625.png'    import {useUserStore} from "../stores/user.js"    import axios from 'axios'    export default{        data(){            return{                background,                loginInfo:{                    phone:"",                    password:""                }            }        },        methods:{            loginUser(){                response = await axios.post('http://127.0.0.1:8000/user/login', this.loginInfo)                if(response.data.code == 200){                    // 登录成功后将用户信息存入pinia,实现组件间的变量共享                    useUserStore().userInfo = response.data.data                    // 同时存入localStorage做持久化缓存                    localStorage.setItem("userInfo", JSON.stringify(response.data.data))                    this.$router.push('/')                }            },            onRegister(){                this.$router.push('/register')            }        }    }  </script>

点击全文阅读


本文链接:http://zhangshiyu.com/post/166461.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

关于我们 | 我要投稿 | 免责申明

Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1