- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是node新手,当我完成我的API后,我意识到它们都是一团糟,并且是一个回调 hell ,这迫使我学习 promise ,现在一切都很好,直到我遇到了一个API条件超过可能的功能,我的问题是如何做嵌套 promise ,我的代码是关于一个父对象,它有一个用户附加到它,当删除路由被调用时有很多条件:
没有 child
一个。这个家长在不止一所学校,school_id 从父对象的学校 id 和附加到它的用户对象中删除
如果这个 parent 没有 child 并且只有 school_id 应该删除它并且附加的用户也应该删除
代码看起来像这样,它是 100% 的功能
router.post('/delete',Validation, function (req, res) {
var school_id = req.body.schoolId;
var parent_id = req.body.selected[0];
/
Student.findOne({parent_ids:parent_id},function(err,parentF){
if(err){
console.log(err);
res.json({status:"error",message:"an error occurred"});
return
}else if(parentF){
res.json({status:"error", message:"you can not delete a parent who has students associated with it"});
return;
}else{
Parent.findOne({_id:parent_id},function(err,parent){
if(err){
console.log(err);
res.json({status:"error",message:"an error occurred"});
return;
}else{
if(parent.school_id.length>1){
var a = parent.school_id.indexOf(school_id);
parent.school_id.pop(a);
parent.save(function(err,parent){
if(err){
console.log(err);
res.json({status:"error",message:"an error occurred"});
return;
}else{
User.findOne({refid:parent_id},function(err,user){
if(err){
console.log(err);
res.json({status:"error",message:"an error occurred"});
return;
}else {
user.school_id.pop(a);
user.save(function(err) {
if(err){
console.log(err);
res.json({status:"error",message:"an error occurred"});
return;
}else{
res.json({status: "success", message: "parent removed"});
return;
}
});
}
});
}
});
}else{
Parent.remove({_id: parent_id}, function (err) {
if (err) {
res.json({status: "error", message: err.message});
} else {
User.remove({refid:parent_id},function(err){
if (err) {
res.json({status: "error", message: "parent user wasn't deleted"});
return;
}else{
res.json({status: "success", message: "parent data successfully deleted"});
return;
}
});
}
});
}
}
});
}
});
});
我正在尝试应用 promises 并使我的代码变得更好。
抱歉这个问题太长了,但我遇到了困难任何建议都表示赞赏
最佳答案
为 findOne 创建一些“promise”风格的函数,删除并保存
let findOneP = (object, params) => new Promise((resolve, reject) => {
object.findOne(params, (err, data) => {
if (err) {
return reject(err);
}
resolve(data);
});
});
let removeP = (object, params) => new Promise((resolve, reject) => {
object.remove(params, (err, data) => {
if (err) {
return reject(err);
}
resolve(data);
});
});
let saveP = (object) => new Promise((resolve, reject) => {
object.save((err, data) => {
if (err) {
return reject(err);
}
resolve(data);
});
});
使用 Bluebird Promisify 可以更轻松地完成上述操作,但是由于您没有指定 bluebird,所以我只是使用了一个快速而肮脏的 promise 包装器
然后使用 promise 链让生活变得轻松
router.post('/delete',Validation, function (req, res) {
var school_id = req.body.schoolId;
var parent_id = req.body.selected[0];
findOneP(Student, {parent_ids: parent_id})
.then(parentF => {
if (parentF) {
throw "you can not delete a parent who has students associated with it";
}
})
.then(() => findOneP(Parent, {_id: parent_id}))
.then(parent => {
if (parent.school_id.length > 1) {
var a = parent.school_id.indexOf(school_id);
parent.school_id.pop(a);
return saveP(parent)
.then(parent => findOneP(User, {refid: parent_id}))
.then(user => saveP(user))
.then(() => "parent removed");
}
return removeP(Parent,{_id: parent_id})
.then(() => removeP(User, {refid: parent_id}))
.then(() => "parent data successfully deleted");
})
.then(message => res.json({status: "success",message}))
.catch(message => res.json({status: "error",message}));
});
我刚读到您使用 Node 4.2 - 您可能需要
如果使用 bluebird,请使用它的 promisify 函数而不是“手动”promisifying
关于javascript - 回调 hell ,厄运金字塔,node.js,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42051494/
我想简化/减少我的代码,所以我尝试将具有重复参数的类的初始化放在它们自己的扩展类中。这是一个基于 Pyramid & Cornice 的 REST API。 我如何初始化 pyramid.httpex
我正在尝试构建一个由 4 个 DIV 组成的金字塔。布局如下所示: ------ | #1 | ------ ---------------- | #2 | #3 | #
我是 3d 绘图的新手。我只想用 5 个点 build 一个金字塔,然后从中切出一个平面。我的问题是我不知道如何填充边。 points = np.array([[-1, -1, -1],
我需要创建金字塔 slider 。 正如您在我当前的实现中看到的那样,我需要有一个位于其余元素顶部的中心图像。它们形成金字塔结构。图像也被放置在彼此下面,这种效果打破了一切,因为我需要转换它们(中心图
我一直在玩我在这里找到的演示:http://codepen.io/singhiskng/pen/dqiGj 我正在尝试制作一个 4 边形金字塔。
在jsp中实现如图所示的金字塔, 代码如下: 大致思路如下: 1、先画出前5行。因为 i+空格数=总行数,所以第一行的空格数是 总行数-i(第几行),然后画出 *,*的数目=2*i-11;
我在尝试找出一种使用用户输入创建金字塔的方法时遇到了很大的麻烦。它应该是这样的。 Enter a number between 1 and 9: 4 O O O O OOOO OOOO OOOO OO
我一直在寻找解决厄运金字塔的办法。到目前为止,我得出的结论如下: router.use('/create', function(res,req,next) { try { v
我刚刚开始处理。因此,我想创建一个函数,允许任何用户输入边数来创建 3D 金字塔。我正在使用处理 3。我需要一些帮助。提前致谢。我编写了一段目前有效的代码,但我想概括它。任何建议/提示将不胜感激。提前
我使用 JavaScript 创建了一个金字塔以下是我迄今为止使用 for 循环尝试的代码: function showPyramid() { var rows = 5; var ou
我被告知数据库超时(连接、交互、等待)设置为 30 秒。该数据库上有一个网站,人们往往会闲置超过 30 秒。 使用sqlalchemy,我需要在继续查询之前检查mysql连接是否仍然有效,否则站点会出
另一个棘手的问题。你在这里看到的是我的物理金字塔,它由 3 个 LED 构成,在 1 个平面上形成一个三角形,另一个 LED 在中间中心,比其他 3 个高约 18 毫米。第 4 个使三角形成为金字塔。
目标: 我正在尝试生成类似于下面给出的格式的金字塔。这需要一个基本的 Java 程序来接受用户输入、将数字转换为字符串、使用嵌套循环并生成格式化输出。下面是使用 8 行的所需输出示例。 Enter t
我的数据是多维组合数据(所有维度总和为 1 或 100)。我已经学会了如何使用三个变量来创建二维三元图。 我想添加第四个维度,使我的情节看起来像这样。 我愿意使用 python 或 R。我现在正在使用
我的数据是多维组合数据(所有维度总和为 1 或 100)。我已经学会了如何使用三个变量来创建二维三元图。 我想添加第四个维度,使我的情节看起来像这样。 我愿意使用 python 或 R。我现在正在使用
我是一名优秀的程序员,十分优秀!