vue3中使用useStore()获取vux中的store踩坑记录

坑的场景

<script setup>
import { computed } from 'vue';
const permissionList = computed(() => {
  const store = useStore(); // 这里不能使用useStore,会报错,因为useStore是在setup中使用的,不能在setup的函数中使用或者说不能在setup的外部使用
  console.log('store', store);
  const storeState = store.getters.permission;
  //用户信息
  const userInfo = store.getters.userInfo;
  return {
    addBtn: storeState.contractSigning_add,
    viewBtn: storeState.contractSigning_view,
    delBtn: storeState.contractSigning_delete,
    editBtn: storeState.contractSigning_edit,
    userInfo: userInfo,
  };
});
<script>

如上述代码,我在setup中的计算属性函数中嵌套使用了const store = useStore(),在下面打印‘store’时,组件会被渲染两次,打印两次,第一次可以打印出来值, 第二次是个undefined,如下图
在这里插入图片描述

错误原因

const store = useStore(); 是否在setup函数下,不可以在setup里的函数的内部,写在函数内部的话就会出现,获取不到store对象的情况,useStore这个方法的调用位置是有要求的,它只能在setup函数中调用,这是它的语法规定。

解决办法

如下,将const store = userStore() 放到setup中定义就可以了

// 获取vuex中的store
const store = useStore();

// 计算属性获取权限
const permissionList = computed(() => {
  // const store = useStore(); // 这里不能使用useStore,会报错,因为useStore是在setup中使用的,不能在setup的函数中使用或者说不能在setup的外部使用
  console.log('store', store);
  const storeState = store.getters.permission;
  //用户信息
  const userInfo = store.getters.userInfo;
  return {
    addBtn: storeState.contractSigning_add,
    viewBtn: storeState.contractSigning_view,
    delBtn: storeState.contractSigning_delete,
    editBtn: storeState.contractSigning_edit,
    userInfo: userInfo,
  };
});
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jieyucx

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值