先是没有加入请求超时的情况:

 

复制代码
var http = require('http');

var url = require('url');

 

function get(addr) {

  return new Promise(function(resolve, reject) {

    var url_obj = url.parse(addr);

    var options = {

      hostname: url_obj.hostname,

      path: url_obj.path,

      method: 'GET'

    };

 

    var req = http.request(options, function(res) {

      res.setEncoding('utf8');

 

      var data = '';

      res.on('data', function (chunk) {

        data += chunk;

      });

      res.on('end', function () {

        data = JSON.parse(data);

        resolve(data);

      });

    });

 

    req.on('error', function(e) {

      reject(e)

    });

    req.end();

  });

}

 

get('http://demos.so/result/homework.promise.userInfo').then(function (args) {

  return Promise.all([get('http://demos.so/result/userid=' + args['_id']), get('http://demos.so/result/student=' + args['_id'])]);

}).then(function (args) {

  console.log(args);

}).catch(function(err){

  console.log(err);

});
复制代码

 

再看一下加入超时的代码:

 

复制代码
var http = require('http');

var url = require('url');

 

function delayPromise(ms) {

    return new Promise(function (resolve) {

        setTimeout(resolve, ms);

    });

}

function timeoutPromise(promise, ms) {

    var timeout = delayPromise(ms).then(function () {

            throw new Error('Operation timed out after ' + ms + ' ms');

        });

    return Promise.race([promise, timeout]);

}

 

function get(addr) {

  return new Promise(function(resolve, reject) {

    var url_obj = url.parse(addr);

    var options = {

      hostname: url_obj.hostname,

      path: url_obj.path,

      method: 'GET'

    };

 

    var req = http.request(options, function(res) {

      res.setEncoding('utf8');

 

      var data = '';

      res.on('data', function (chunk) {

        data += chunk;

      });

      res.on('end', function () {

        data = JSON.parse(data);

        resolve(data);

      });

    });

 

    req.on('error', function(e) {

      reject(e)

    });

    req.end();

  });

}

 

timeoutPromise(get('http://demos.so/result/homework.promise.userInfo'),1000).catch(function (err) {

  console.log(err);

}).then(function (args) {

  return Promise.all([timeoutPromise(get('http://demos.so/result/userid=' + args['_id']), 1000), timeoutPromise(get('http://demos.so/result/student=' + args['_id']), 1000)]);

}).then(function (args) {

  console.log(args);

}).catch(function (err) {

  console.log(err);

});
复制代码

 

 

 

  原理其实很简单,就是利用Promise.race,我们先创建一个Promise,里面用setTimeout进行处理,然后将新创建的Promise与我们之前使用的Promise"比赛"一下。

posted on   ygunoil  阅读(1226)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
· AI Agent开发,如何调用三方的API Function,是通过提示词来发起调用的吗
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示