• uniapp vue3 使用pinia存储 并获取数据


    存token 

    1. import { defineStore } from 'pinia';
    2. export const userInfo = defineStore('userInfo', {
    3. state: () => {
    4. return {
    5. userToken: uni.getStorageSync('token') || '',
    6. };
    7. },
    8. actions: {
    9. // 添加token
    10. updateToken(token: string) {
    11. uni.setStorageSync('token', token);
    12. this.userToken = token
    13. }
    14. }
    15. });

    使用

    1. import {
    2. userInfo
    3. } from '@/stores/userInfo'
    4. import {
    5. ref
    6. } from "vue";
    7. const test = userInfo()
    8. const tst = ref('4')
    9. test.updateToken(tst.value)

    效果

    这边存 用户信息

    定义store 文件

    1. import { defineStore } from 'pinia'
    2. interface Member {
    3. userInfo : AnyObject | null
    4. }
    5. const useMemberStore = defineStore('member', {
    6. state: () : Member => {
    7. return {
    8. userInfo: uni.getStorageSync('userInfo') || null
    9. }
    10. },
    11. actions: {
    12. updateUserInfo(userInfo : AnyObject) {
    13. uni.setStorageSync('userInfo', userInfo)
    14. this.userInfo = userInfo
    15. }
    16. }
    17. })
    18. export default useMemberStore

     vue页面 存储数据

    1. import useMemberStore from '@/stores/member'
    2. const user = useMemberStore()
    3. user.updateUserInfo('存对象的数据')

    取数据

    方法一

    弊端 没有初始值 控制台提示报错

    在template中 使用 userInfo.member_id

    1. import { storeToRefs } from 'pinia'
    2. import useMemberStore from '@/stores/member'
    3. const info = useMemberStore()
    4. const { userInfo } = storeToRefs(info)
    5. console.log(userInfo.value.member_id, '从缓存中取数据');

    打印下 userInfo 

    方式二 

    默认值 即使userInfo无值也不会报错

    1. template中 直接 {{member_id}} 使用
    2. import useMemberStore from '@/stores/member'
    3. import { ref, computed } from "vue";
    4. const memberStore = useMemberStore()
    5. const userInfo : any = computed(() => memberStore.userInfo)
    6. const member_id = ref(0)
    7. const is_mechanic = ref(0)
    8. if (userInfo.value) {
    9. member_id.value = userInfo.value.member_id
    10. is_mechanic.value = userInfo.value.is_mechanic
    11. }
  • 相关阅读:
    traffic control
    2024.6.13刷题记录
    STM32 如何定位导致发生 hard fault 的代码段
    metersphere 创建场景, 自动动态变换参数值,实现接口自动化测试。
    项目部署服务器--浏览器拒绝访问问题
    如何使用CSS实现一个带有动画效果的折叠面板(Accordion)?
    vscode微博发布案例
    5、Linux文件系统
    Java - 工具类参数初始化
    thinkphp+vue+antpro前后端权限管理系统
  • 原文地址:https://blog.csdn.net/LJM51200/article/details/133877033