【ES6】16.generator函数的语法 10.(1)异步操作的同步化表达

谢谢阮老师的ES6!

16.generator函数的语法

10.(1)异步操作的同步化表达

=======================分割线=======================

通过generator函数部署ajax操作,用同步的方式表达

1.makeAjaxCall函数

//忽略浏览器兼容性

function makeAjaxCall(url,callback){
  console.log("开始向"+url+"进行异步请求");
  var xmlhttp = new XMLHttpRequest();
xmlhttp.onreadystatechange=function()
  {
  if (xmlhttp.readyState==4 && xmlhttp.status==200)
    {
    console.log("回调开始");
    callback(xmlhttp.responseText);
    }
  }
  xmlhttp.open("GET",url,true);
  xmlhttp.send(null);
 
}

2.request函数

function request(url){
makeAjaxCall(url, function(response){
console.log(response);    
it.next(response);
  });
}

3.generator函数

function* main(){
  var result = yield request("http://localhost:8888/initRecords.action");
  alert(result);
}
var it=main();


总结:

异步的同步表达。如果在makeAjaxCall使用同步请求open(,,false),则报错Generator is already running。应该是因为同步的状态下,前一次的next没执行完,所以无法启动下一次next吧。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值