javascript-Request-Promise:不要承诺缓存结果
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript-Request-Promise:不要承诺缓存结果,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1289字,纯文字阅读大概需要2分钟。
内容图文
![javascript-Request-Promise:不要承诺缓存结果](/upload/InfoBanner/zyjiaocheng/680/c33524615be5462da0621f44ca2818cb.jpg)
我正在使用Request-Promise(请参见下面的代码).
问题:如果我缓存了一个诺言,它会缓存结果还是每次都问一个新的诺言?
例:
var cachedPromise = getTokenPromise();
cachedPromise.then(function(authorizationToken1) {
//...
});
cachedPromise.then(function(authorizationToken2) {
//...
});
//QUESTION: Is right that authorizationToken1 equals authorizationToken2
getTokenPromise()函数:
var querystring = require('querystring');
var rp = require('request-promise');
/**
* Returns an authorization token promise
*/
function getTokenPromise() {
var requestOpts = {
encoding: 'utf8',
uri: 'https://datamarket.accesscontrol.windows.net/v2/OAuth2-13',
method: 'POST',
body: querystring.stringify({
'client_id': 'Subtitles',
'client_secret': 'Xv.............................s=',
'scope': 'http://api.microsofttranslator.com',
'grant_type': 'client_credentials'
})
};
return rp(requestOpts);
}
解决方法:
If I cache a promise, do it cache the result
一个承诺只能有一个结果(以防不被拒绝).因此,它也只能被解析一次,并且此后不得更改其状态.
实际上,promise spec个州
- When fulfilled, a promise:
- must not transition to any other state.
- must have a value, which must not change.
or each time ask a new one?
否.getTokenPromise()是请求令牌的调用,并且仅执行一次. cachedPromise仅表示结果,而不表示操作.即使您没有通过.then()添加回调,动作本身也会被执行.
内容总结
以上是互联网集市为您收集整理的javascript-Request-Promise:不要承诺缓存结果全部内容,希望文章能够帮你解决javascript-Request-Promise:不要承诺缓存结果所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。