首页 > 解决方案 > 将 memoizee 与 TypeScript 的类一起使用

问题描述

我想在使用memoizee库的 TypeScript 类中使用记忆技术。

这是我已经尝试过的一些代码:

import memoize from "memoizee"
import { getModule, Module, MutationAction, VuexModule } from "vuex-module-decorators"
import store from "@/store"
import { User } from "./models"
import { UserAPI } from "./api"

@Module({ namespaced: true, name: "user", store, dynamic: true })
class UserModule extends VuexModule {
  user: User | null = null
  getUser = memoize(UserAPI.getUser, { maxAge: 10 * 60 * 1000, promise: true })

  @MutationAction
  async fetchProfile() {
    const user = await this.getUser()
    return { user }
  }
}

export default getModule(UserModule)

不幸的是,它是无效的,因为TypeError: this.getUser is not a function. 这是为什么?以及如何在 TypeScript 的类中正确使用 memoizee?

标签: typescriptvue.jsvuexmemoizationmemoizee

解决方案


您可能需要以不同的方式导入 memoize。

这对我有用:

import * as memoizee from 'memoizee';

推荐阅读