将 memoizee 与 TypeScript 结合使用 类
Using memoizee with TypeScript's classes
我想使用 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 类?
您可能需要以不同方式导入 memoize。
以下是对我有用的方法:
import * as memoizee from 'memoizee';
我想使用 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 类?
您可能需要以不同方式导入 memoize。
以下是对我有用的方法:
import * as memoizee from 'memoizee';