I need a method to retrieve different scripts with a callback. This method works fine:
fetchScripts:function() { var _this=this; $.when( $.ajax({ url:_this.url + 'library/script-one.js', type:'get', cache:true }), $.ajax({ url:_this.url + 'library/script-two.js', type:'get', cache:true }), { .... }, $.ajax({ url:_this.url + 'library/script-n.js', type:'get', cache:true }) ).then(function() { console.log('fetch is done'); }) },
But I would like to generalize the method more because redundany is increasing. Is it possible to convey the promise of $ .when ()? Below my first attempt - but the url is always the same, that is, script -n.js' Maybe I missed this point and you could illustrate a more "colorful" solution.
fetchScripts:function() { this.deferred=new $.Deferred(); this.promise=this.deferred.promise(); var _this=this; $.each([ 'script-one.js', 'script-two.js', ( .... ), 'script-n.js' ],function() { _this.script=this; _this.promise.then(function(){ return $.ajax({ url:_this.url + 'library/' + _this.script, type:'get', cache:true }) }); }); $.when( this.promise ).then(function() { console.log('fetch is done'); }); this.deferred.resolve(); },
campari
source share