Žig*_*pan 3 javascript node.js express sequelize.js
因此,在我的express应用程序中,我有一个单独的文件database.js,其中包含用于插入、删除、更新等的所有模型和函数。我还为每个模型都有一个单独的控制器。
数据库.js
module.exports = {
createUser: function (username, email, password) {
return sequelize.sync().then(function () {
User.findOrCreate({
where: {
username: name,
email: email
},
defaults: {
username: username,
password: password,
email: email
}
}).then(([user, created]) => {
console.log(user.get({plain:true}));
console.log(created)
});
});
}
};
Run Code Online (Sandbox Code Playgroud)
控制器/user.js
const database = require("../database.js");
module.exports = {
register: function (req, res) {
database.createUser(req.body.username, req.body.email, req.body.password);
res.json({...
})
}
};
Run Code Online (Sandbox Code Playgroud)
所以基本上我想获取用户对象和布尔值,告诉我它是否已创建到路由器,以便我可以检查用户是否已创建并做出适当的响应。
您可以在 createUser 中删除then并在调用该函数时解析 Promise:
module.exports = {
createUser: function (username, email, password) {
return User.findOrCreate({
where: {
username: name,
email: email
},
defaults: {
username: username,
password: password,
email: email
}
})
};
Run Code Online (Sandbox Code Playgroud)
然后,该承诺将解析为一个包含用户对象和您要查找的布尔值的数组
const database = require("../database.js");
module.exports = {
register: function (req, res) {
database.createUser(req.body.username, req.body.email, req.body.password)
.then((result) => {
const [ object, created ] = result;
res.json({ user_is_created: created })
})
}
};
Run Code Online (Sandbox Code Playgroud)
这不是一个完整的解决方案,您可能必须探索边缘情况和错误,但这基本上就是您的做法。