js 使用generator函數同步執行ajax任務

 
 
//@author wangbinandi@gmail.com

function
request(url, callback) { fetch(url, {mode: 'cors', credentials: 'include', headers: new Headers({ 'X-Requested-With': 'XMLHttpRequest' })}) .then(response => response.text()) .then(text => { console.log(url); console.log(text); callback(text); }) .catch((e) => console.log(e)); } var iterator = null; function getData(src){ request(src, function(response){ iterator.next(JSON.parse(response)); }) } function getTpl(src){ request(src, function(response){ iterator.next(response); }); } // 同步任務 function render(data, tpl){ for(var i in data) { tpl = tpl.replace("${"+i+"}", data[i]); } return tpl; } // 主邏輯 var getArticles = function* (src){ console.log('begin') var data = yield getData(src) var tpl = yield getTpl(data.tpl) var res = render(data, tpl) console.log(res) } iterator = getArticles('data.json') // 開始執行 iterator.next() // 異步任務模型

 更簡短的 async 函數json

// @author wangbinandi@gmail.com

async function getArticles2(url) {
 console.log(url);
  var res1 = await fetch(url);
  var data = await response.json();
  var res2 = await fetch(data.tpl);
  var tpl  = await res2.text();
  return render(data, tpl)
}

getArticles2('data.json').then(console.log)
相關文章
相關標籤/搜索