是否可以使用TypeOrm保留类型安全性来设置对象的字段值?
我在文档中找到的所有示例都建议您一对一设置属性
const newUser = new User();
newUser.firstName = 'John'
newUser.lastName = 'Doe'
newUser.role = 'manager'
newUser.phone = '1234567890'
newUser.login = 'john.doe'
newUser.password = '12345'
newUser.save();
如果我可以这样设置字段,那就更好了
const newUser = new User();
newUser.setFields({
firstName: 'John',
lastName: 'Doe',
role: 'manager',
phone: '1234567890',
login: 'john.doe',
password: '12345'
}
);
newUser.save();
它将允许使用快捷方式
const newUser = new User();
newUser.setFields({
firstName,
lastName,
role,
phone,
login: 'john.doe',
password: '12345'
}
);
newUser.save();
并使用合成
const newUser = new User();
newUser.setFields({
firstName,
lastName,
role,
phone,
...credentials
}
);
newUser.save();
尽管我找不到任何方法。
我知道您需要具有一种描述对象形状的类型才能实现它,但是我希望TS / TsOrm可以从我定义的模型中以某种方式派生它。
答案 0 :(得分:1)
您最有可能寻找实体或存储库的create
和merge
方法(取决于您的实现):
const userEntity = UserEntity.create({ firstName, lastName, ...someOtherStuff });
const mergedEntity = UserEntity.merge(mergedEntity, { lastName: "new last name" });
有关更多信息,请查阅documentation并向下滚动至所提到的方法,其中包括以下示例:
const user = repository.create(); // same as const user = new User();
const user = repository.create({
id: 1,
firstName: "Timber",
lastName: "Saw"
}); // same as const user = new User(); user.firstName = "Timber"; user.lastName = "Saw";
const user = new User();
repository.merge(user, { firstName: "Timber" }, { lastName: "Saw" });
// same as user.firstName = "Timber"; user.lastName = "Saw";