我有異步代碼段,這段代碼其實是 new Promise() 的對象,但是我需要多次循環(huán)這個對象同時獲取其中的值,代碼如下:
module.exports = function (options) {
var nodegit = require("nodegit");
var configs = [
{
"path": "path1",
"branch": ""
},
{
"path": "path2",
"branch": ""
}
];
for (var i = 0; i < configs.length; i++) {
nodegit.Repository.open(configs[i].path).then(function (repo) {
return repo.getCurrentBranch();
}).then(function (reference) {
configs[i].branch = reference.name();
return reference;
});
}
console.log(configs);
};
上面的代碼的意思是根據(jù)configs.path來更新configs.branch;但是 nodegit 使用的是 Promise 同步執(zhí)行模式,請問我如何能獲取 Promise.then 的數(shù)據(jù),或者上面的代碼如何修改比較合適?謝謝!
難道我需要通過循環(huán)一層一層的 then 下去?
你的代碼沒什么大問題,主要是第二個configs[i]用錯了,再了解一下Promise.all就知道怎么寫了;
參考代碼:
module.exports = function (options) {
var nodegit = require("nodegit");
var configs = [
{
"path": "path1",
"branch": ""
},
{
"path": "path2",
"branch": ""
}
];
var getBranch = function(path){
return nodegit.Repository.open(path).then(function (repo) {
return repo.getCurrentBranch();
})
}
var promises = configs.map(v=>{
return getBranch(v.path).then(reference=>{
v.branch = reference.name();
return v;
})
})
return Promise.all(promises)
};
@unicreators 的效率會差一點
@RandyO 的代碼和我的代碼意思差不多,只是那個All應(yīng)該是小寫
async/await是好東西,但建議先完全搞清楚Promise再使用.
使用 es6 async/await
var nodegit = require("nodegit");
module.exports = async function (paths) {
let result = [];
for (var i = 0; i < paths.length; i++) {
let repo = await nodegit.Repository.open(paths[i]);
let reference = await repo.getCurrentBranch();
result.push({ path: paths[i], reference, branch: reference.name() });
}
return result;
};
使用await調(diào)用
let result = await require('...')(['path1','path2', 'pathN']);
// or
require('...')(['path1','path2', 'pathN']).then(result){
// ...
}var nodegit = require("nodegit");
module.exports = async function(options) {
var configs = [{
"path": "path1",
"branch": ""
}, {
"path": "path2",
"branch": ""
}];
var promises = []
for (let i = 0; i < configs.length; i++) {
promises.push(nodegit.Repository.open(configs[i].path));
}
const repos = await Promise.All(promises);
for (let i = 0; i < configs.length; i++) {
let reference = await repos[i].getCurrentBranch();
configs[i].branch = reference.name();
}
console.log(configs);
}
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
達內(nèi)教育集團成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學(xué)校辦產(chǎn)業(yè)為響應(yīng)國家深化產(chǎn)教融合/校企合作的政策,積極推進“中國制造2025”,實現(xiàn)中華民族偉大復(fù)興的升級產(chǎn)業(yè)鏈。利用北京大學(xué)優(yōu)質(zhì)教育資源及背
博為峰,中國職業(yè)人才培訓(xùn)領(lǐng)域的先行者
曾工作于聯(lián)想擔任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責任公司從事總經(jīng)理職務(wù)負責iOS教學(xué)及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術(shù)功底深厚。 授課風格 授課風格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。