node.js使用promise如果有if...else怎么改成链式的

新手上路,请多包涵

回调里面有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判断的改这么改成链式

阅读 1.9k
1 个回答

基本上实现不了,用async/await吧

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题