自定义JQuery延迟处理程序

时间:2013-04-18 16:28:14

标签: javascript jquery deferred

不确定这是否可行,但我会试一试。我有一个延迟函数,它调用服务器来创建或更新和对象。例如:

var createOrUpdate = function(item) {
    var self = this;
    var deferred;

    if (item.id && item.id > 0) {
        updated = true;
        deferred = update.call(self, params);
    } else {
        deferred = create.call(self);
    }

    return deferred;
};

其中create和call方法返回deferred自己。这将允许我打电话

foo.createOrUpdate(bar).then(function(response) {
    // something happened
});

但是我希望能够添加一些自定义的延迟处理程序,以便我可以这样做

foo.createOrUpdate(bar).created(function(response) {
    // an item was created
}).updated(function(response) {
    //an item was updated
});

首先,这是可能的吗?其次,如果是这样,我该怎么做呢。

基本上我想创建一个自定义的延迟处理程序。

非常感谢。

2 个答案:

答案 0 :(得分:1)

未经过真正测试:

var createOrUpdate = function(item) {
  return {
    isUpdated : item.id && item.id > 0,
    created   : function(cb) {
      if (! this.isUpdated)
        create.call(self).then(cb);
      return this;
    },  
    updated   : function(cb) {
      if (this.isUpdated)
        update.call(self, params).then(cb);
      return this;
    }   
  };  
};  

foo.createOrUpdate(bar)
  .created(function(response) {
    // an item was created
  })
  .updated(function(response) {
    //an item was updated
  });

答案 1 :(得分:1)

一种解决方案是创建自己的$.Deferred个对象,然后使用.resolve发送一个参数,说明它是哪种方法。

例如:

function create(){
    var deferred = new $.Deferred;

    $.post('/your/AJAX/call', {your: data}, function(retData){
        deferred.resolve('create', retData);
    });

    return deferred.promise();
}

function update(params){
    var deferred = new $.Deferred;

    $.post('/your/AJAX/call', {your: data, also: params}, function(retData){
        deferred.resolve('update', retData);
    });

    return deferred.promise();
}

保持createOrUpdate相同,您可以使用.then,并且您将从.resolve传递两个参数。

foo.createOrUpdate(bar).then(function(method, response) {
    switch(method){
        case 'update':
            break;
        case 'create':
            break;
    }
});

这是一个小型演示:http://jsfiddle.net/U5jyJ/