ajax async false beforeSend无效解决方案
发布时间:2020-12-16 02:04:10 所属栏目:百科 来源:网络整理
导读:解决方案 把ajax改为异步,用deferred 代码 function renderChildData(d) { var params = '' + d.hasNewChild + 'baseTime=' + getparams().baseTime + 'period=' + getparams().period; var childTreeData = null; var deferred = $.Deferred(); var reques
解决方案把ajax改为异步,用deferred 代码function renderChildData(d) { var params = '&' + d.hasNewChild + '&baseTime=' + getparams().baseTime + '&period=' + getparams().period; var childTreeData = null; var deferred = $.Deferred(); var request = $.ajax({ url: api.childTree + params,type: 'GET',data: {},beforeSend: function () { $('#childLoading').html(common.loadingImg); },dataType: 'json' }); request.done(function (json) { $('#childLoading').empty(); if (json.success) { var data = json.data; childTreeData = mapTreeData(data); deferred.resolve(childTreeData); } else { nuit.msg({type: 'warn',msg: json.msg,closable: true,timeoutclose: true}); deferred.reject(childTreeData); } return childTreeData; }); request.fail(function () { $('#childLoading').empty(); deferred.reject(childTreeData); }); return deferred; } renderChildData(d).then(function (child) { // 这里的child 就是renderChildData 返回的childTreeData } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |