如何解决axios 请求问题的速率限制/节流
在这个类中,get(item)
方法返回一个 promise,其中包含从 axios 调用中获得的响应数据对象
const wait = ms => new Promise(resolve => setTimeout(resolve,ms));
class MyClass {
constructor () {}
get(item){
console.log(`making request`);
return wait(250).then(
axios.get(`https://some_url.com/${item.id}`,{
params: { api_key: "some_key" }
}).then((response) => {
console.log(`RESPONSE IS ${response}`);
return new Promise( (resolve) => { return resolve(response); })
})
)
}
}
module.exports = MyClass;
这是重复调用get(item)
axios 包装方法的外部函数。
它使用的是 bluebirdjs 的 Promise.mapseries
(http://bluebirdjs.com/docs/api/promise.mapseries.html)
var myClass = require('./myClass');
...
bluebird.mapSeries(someArray),function(arrayItem){
return new myClass().get(arrayItem)
.then((response_object) => {
//TypeError: Cannot read property 'then' of undefined
});
})
.then(function(something){
// do nothing
})
});
...
代码在更高级别的函数中失败,它在具有 TypeError: Cannot read property 'then' of undefined
延迟的 axios 完成之前执行时抛出 250ms
这个实现不起作用,我正在寻找修复它并正确地限制/节流
感谢反馈
解决方法
从此改变:
return wait(250).then(axios.get(...))
为此:
return wait(250).then(() => axios.get(...))
您必须将函数引用传递给 .then()
,以便稍后调用它。您立即调用它并将其返回结果传递给 .then()
,这不是 .then()
的工作方式。
另外,改变这个:
return new Promise( (resolve) => { return resolve(response); })
到
return response;
因为他们完成了同样的事情,但第二个要简单得多。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。