回调里面有if语句,再进入不同的回调的时候,一个怎么改成链式。
const selArr = [userid, body.goodsid];
const insArr = [userid, body.goodsid];
const delArr = [userid, req.body.goodsid];
// mysql
const select = "select * from xx_member_favorite_product where FAVORITE_MEMBERS = ? AND FAVORITE_PRODUCTS = (SELECT ID FROM xx_product WHERE SN = ?)";
const insert = "insert into xx_member_favorite_product set FAVORITE_MEMBERS = ?, FAVORITE_PRODUCTS = (SELECT ID FROM xx_product WHERE SN = ?)";
const del = "delete from xx_member_favorite_product where FAVORITE_MEMBERS = ? and FAVORITE_PRODUCTS = (SELECT ID FROM xx_product WHERE SN = ?)";
sqInfo.query(select, selArr)
.then( oldData => {
const data = oldData[0];
if (data) {
/**已有的话删除 */
sqInfo.query(del, delArr)
.then( () => {
return res.status(200).json({
err_code: 1,
message: "移出收藏夹成功!"
});
})
.catch( err => {
next(err);
})
}
if (!data) {
sqInfo.query(insert, insArr)
.then( () => {
return res.status(200).json({
err_code: 0,
message: "收藏成功!"
});
})
.catch( err => {
next(err);
})
}
})
.catch( err => {
next(err);
})
这种里面有if判断的改这么改成链式
基本上实现不了,用async/await吧