加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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
     }

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读