JavaScript中怎么使用generator函数同步执行ajax任务
短信预约 -IT技能 免费直播动态提醒
JavaScript中怎么使用generator函数同步执行ajax任务,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
具体内容如下
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(class="lazy" data-src){
request(class="lazy" data-src, function(response){
iterator.next(JSON.parse(response));
})
}
function getTpl(class="lazy" data-src){
request(class="lazy" data-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* (class="lazy" data-src){
console.log('begin')
var data = yield getData(class="lazy" data-src)
var tpl = yield getTpl(data.tpl)
var res = render(data, tpl)
console.log(res)
}
iterator = getArticles('data.json')
// 开始执行
iterator.next()
// 异步任务模型
看完上述内容,你们掌握JavaScript中怎么使用generator函数同步执行ajax任务的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网行业资讯频道,感谢各位的阅读!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341