在 Express 中,`then` 方法通常用于 Promise 链式调用。

在 Express 中,`then` 方法通常用于 Promise 链式调用。在路由设置中,如果使用了 Promise 完成异步操作,则可以在 Promise 完成后继续执行下一步操作,例如发送响应。

 

下面是一个使用 then 方法的示例:

 

```javascript

const express = require('express');

const app = express();

 

function getData() {

  return new Promise((resolve, reject) => {

    setTimeout(() => {

      resolve('Hello World');

    }, 1000);

  });

}

 

app.get('/', (req, res) => {

  getData()

    .then(data => {

      // 在 Promise 完成后发送响应

      res.send(data);

    })

    .catch(err => {

      // 处理错误

      console.error(err);

      res.status(500).send('Internal Server Error');

    });

});

 

const port = 3000;

app.listen(port, () => {

  console.log(`Server listening on port ${port}`);

});

```

 

在上述代码中,我们定义了一个 `getData` 函数,它返回一个 Promise,在 1 秒后解析为字符串 `'Hello World'`。在 Express 应用中,我们使用 `app.get` 方法定义了一个路由,当有 GET 请求访问 '/' 路径时,回调函数会调用 `getData` 方法获取数据。在 Promise 完成后,我们使用 `then` 方法发送响应,如果发生错误,我们使用 `catch` 方法处理错误并发送 500 错误响应。最后,我们使用 `app.listen` 方法启动 Express 应用并监听 3000 端口。

 

通过这个示例,我们可以看到在 Express 应用中使用 then 方法可以方便地进行异步操作和响应处理。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值