これが私がこれを行う方法です:
- TypeScriptクラスを定義する これでロジックが定義されます。
- インターフェースを定義する (私はDocumentと名付けています):それはタイプ
mongoose
です と相互作用します - モデルを定義します(検索、挿入、更新が可能になります...)
コード内:
import { Document, Schema, model } from 'mongoose'
// 1) CLASS
export class User {
name: string
mail: string
constructor(data: {
mail: string
name: string
}) {
this.mail = data.mail
this.name = data.name
}
/* any method would be defined here*/
foo(): string {
return this.name.toUpperCase() // whatever
}
}
// no necessary to export the schema (keep it private to the module)
var schema = new Schema({
mail: { required: true, type: String },
name: { required: false, type: String }
})
// register each method at schema
schema.method('foo', User.prototype.foo)
// 2) Document
export interface UserDocument extends User, Document { }
// 3) MODEL
export const Users = model<UserDocument>('User', schema)
これをどのように使用しますか?コードがuser.ts
に保存されていると想像してみましょう。 、これで次のことができるようになります:
import { User, UserDocument, Users } from 'user'
let myUser = new User({ name: 'a', mail: '[email protected]' })
Users.create(myUser, (err: any, doc: UserDocument) => {
if (err) { ... }
console.log(doc._id) // id at DB
console.log(doc.name) // a
doc.foo() // works :)
})