js使用generator函数同步执行ajax任务

本文实例为大家分享了js使用generator函数同步执行ajax任务的具体代码,供大家参考,具体内容如下

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()
// 异步任务模型

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

IE6是一个非常老旧的网页浏览器,虽然现在很少人再使用它,但...
PHP中的count()函数是用来计算数组或容器中元素的个数。这个...
使用 AJAX(Asynchronous JavaScript and XML)技术可以在不...
Ajax(Asynchronous JavaScript and XML)是一种用于改进网页...
本文将介绍如何通过AJAX下载Excel文件流。通过AJAX,我们可以...
Ajax是一种用于客户端和服务器之间的异步通信技术。通过Ajax...