weixin_33724046 2015-06-08 14:12 采纳率: 0%
浏览 1077

在ajax调用中使用.then

I have an ajax call:

p.data = function(){

    return $.ajax({
        url: '/data',
        type: 'POST'
    }).done(function(data){
        console.log('done');
        //do something with data here
        p.dummyDataVar = data[0];
    })
    .fail(function(){
        console.log('fail');
    }).
    always(function(){
        console.log('always');
    });

};

This is called by:

this.data()
    .then(p.mySecondFunction);

I wish to call the data, then on done assign some vars with that data, then once this is all done I want to do mySecondFunction. But in the above code the second function is happening before the ajax call.

Also, I would like mySecondFunction to be called not matter whether the ajax call fails or not.

  • 写回答

2条回答 默认 最新

  • weixin_33725270 2015-06-08 14:17
    关注

    You can use .always() for this. It's already in you code.

    Add handlers to be called when the Deferred object is either resolved or rejected.

    p.data = function () {
    
        return $.ajax({
            url: '/data',
            type: 'POST'
        }).done(function (data) {
            console.log('done');
            //do something with data here
            p.dummyDataVar = data[0];
        })
        .fail(function () {
            console.log('fail');
        }).always(function () {
            //Call whatever you want
        });
    
    };
    
    评论

报告相同问题?