ajax 保存变量值,Javascript:将AJAX结果保存为Class变量

最重要的部分是如何使用JavaScript处理异步数据.有一些经过很好测试的解决方案:功能和承诺.

在两个cass中,Reader应该有一个构造函数来分配这样的数据:

function Reader(data) {

this.data = data;

}

回调方法需要一个具有回调函数的工厂函数.

function getReader(url,callBack) {

Ajax.success(function(data){

callBack( new Reader(data) );

});

}

并使用它

getReader(url,function(reader) {

reader.searchData();

});

Promise -approach不需要立即回调,所以结果可以存储在一个变量中,并作为一个变量传递,这个变量有一些优点:

function getReaderPromise(url) {

return new Promise( function( resolve,reject ) {

Ajax.success(function(data){

resolve( new Reader(data) );

});

});

}

然而,使用承诺通常需要调用那个承诺的功能:

getReaderPromise(url).then( function(reader) {

reader.searchData();

});

// Fat arrow Syntax

getReaderPromise(url).then( (reader) => {

reader.searchData();

});

在将来,您可以使用具有收益的ES6发生器的Promises来消除回调

let reader = yield getReaderPromise( url );

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值