• 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. }
  • 相关阅读:
    VS2022创建控制台应用程序后没有Main了,如何显示Main?
    【分布式金融交易模型】服务调用
    [拒绝高深莫测] 区块链与比特币0基础科普
    crontab定时任务是否执行
    为什么国内用户不选择商务智能(BI)工具?_光点科技
    一个关于 i++ 和 ++i 的面试题打趴了所有人
    华硕主板开启核显
    Java内存模型基础(JMM)
    从头开始实现YOLOV3
    JSqlParser入门教程之常用示例
  • 原文地址:https://blog.csdn.net/LJM51200/article/details/133877033