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

发布于:2024-04-27 ⋅ 阅读:(24) ⋅ 点赞:(0)

坑的场景

<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,
  };
});