Общие сведения о jQuery Deferred.pipe ()

Я пытаюсь реализовать метод jQuery Deferred.pipe () для следующего сценария:

  1. Добавить пользователя в БД через $ .ajax ()
  2. Получить ответ, если пользователь был добавлен правильно или нет.
  3. В случае успешного добавления получить весь список пользователей с сервера через $ .ajax ()
  4. Показать список с помощью шаблонов jQuery

Это то, что я пробовал:

var addUserSuccess = function( data ) {
    if ( data.returnCode !== "success" ) {
        return $.Deferred().reject('Error saving user');
    }
    getUsers();
}

var addUser = function() {
    return $.ajax(url, {
        type: "POST",
        data: { username: 'test' },
        contentType: "application/json",
        dataType: "json"
    });
}

var displayUsers = function( data ) {
    $('#myTmpl').tmpl(data.d).appendTo('#myDiv');
}

var getUsers = function () {
    return $.ajax(url, {
        type: "GET",
        data: {},
        contentType: "application/json",
        dataType: "json"
    });
}

$.when(addUser()).pipe(addUserSuccess).then(displayUsers)

Но это не работает. Я знаю, что чего-то не хватает или что-то не так. Любая помощь?

20
задан Ashish 7 May 2011 в 13:11
поделиться