TypeScript & Sequelize:传入泛型模型

Mor*_*anR 3 sequelize.js typescript typescript-generics

我有这个代码

import { Model, DataTypes, Sequelize } from "sequelize";

class User extends Model {
    public id!: number;
    public firstName!: string;
    public readonly createdAt!: Date;
    public readonly updatedAt!: Date;
}

function async InitAndDefineModel(model: Model): void {
    const sequelize = new Sequelize({
        dialect: "sqlite",
        storage: ":memory:",
    });
    model.init{
        firstName: {
            allowNull: false,
            type: DataTypes.STRING,
        },
    },
    {
        sequelize,
    });
    const tables = await sequelize.showAllSchemas({});
    console.log(tables);
}

InitAndDefineModel(User);
Run Code Online (Sandbox Code Playgroud)

console.log 语句返回:

// [ { name: 'Users' } ]
Run Code Online (Sandbox Code Playgroud)

所以我知道代码有效,但是,TypeScript 抱怨说:

Property 'init' is a static member of type 'Model<any, any>'ts(2576)
Run Code Online (Sandbox Code Playgroud)

model.init(...)通话中。

我认为 TS 认为我传入了一个 Model 对象目录。我想我需要告诉它它是一种模型,或者传入的对象是从它扩展而来的。我如何告诉 TypeScript 参数model: Model是有效的?我尝试使用model: Model<T>和 `model: T 任何其他变体,但无济于事。

pio*_*ias 6

您应该创建模型的静态类型表示,例如:

type ModelStatic = typeof Model & {
  new(values?: object, options?: Sequelize.BuildOptions): Model;
}
Run Code Online (Sandbox Code Playgroud)

你可以这样定义InitAndDefineModel函数:

function async InitAndDefineModel(model: ModelStatic): void
Run Code Online (Sandbox Code Playgroud)

在这种情况下,model传递给上面的函数现在应该允许访问静态方法Sequelize.Model