首页  >  问答  >  正文

如何从 Pinia getter 有条件地解构对象属性?

我有以下商店:

export const useMyStore = defineStore('myStore', {
  state: () => {
    return {
      openTransOnly: false,
      keyword: '',
      openTransStatus: { nextPage: 0, complete: false },
      pastDueTransStatus: { nextPage: 0, complete: false },
    };
  },

  getters: {
    transStatus(state) {
      return state.openTransOnly ? state.openTransStatus : state.pastDueTransStatus;
    },
  },
});

现在假设我想将上面的“keyword”属性转换为 Ref。我是这样做的:

const myStore = useMyStore();
const { keyword: needle } = storeToRefs(myStore);

我的组件中还有以下计算属性:

const page = computed({
  get: () => myStore.transStatus.nextPage,
  set: (value) => (myStore.transStatus.nextPage = value),
});

效果很好。但是,我想知道如何使用上面相同的“storeToRefs”来定义“页面”。我试过这个:

const { keyword: needle, transStatus: { nextPage: page } } = storeToRefs(myStore);

但它说“页面未定义”。我究竟做错了什么?这可能吗?

P粉148434742P粉148434742345 天前715

全部回复(1)我来回复

  • P粉394812277

    P粉3948122772023-11-09 09:55:18

    正如 storeToRefs 名称所示,它返回引用。 transStatus 是一个引用,没有 nextPage 属性,它是 transStatus.value.nextPage。由于 transStatus 的工作方式以及该值是标量,过早解构 nextPage 会导致反应性丧失。

    如果这是常见的使用场景,商店可以合并 page 计算。由于商店状态不应在商店外部发生变化,因此 page 可以与 setPage 操作结合使用。

    回复
    0
  • 取消回复