20

次のシナリオで jQuery Deferred.pipe() メソッドを実装しようとしています。

  1. $.ajax() 経由で DB にユーザーを追加します
  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)

しかし、これはうまくいきません。私は何かが欠けているか間違っていることを知っています。何か助けはありますか?

4

1 に答える 1