自定义JQuery延迟处理程序
Custom JQuery deferred handler
不确定这是否可能,但我会尝试一下。我有一个延迟函数,它调用服务器来创建或更新对象。例如:
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方法返回自己的延迟值。这将允许我调用
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
});
首先,这可能吗?其次,如果是这样,我该怎么做呢?
基本上我想创建一个自定义延迟处理程序。
许多谢谢。没有真正测试:
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
});
一个解决方案是创建自己的$.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/
相关文章:
- keyup事件处理程序更改焦点不适用于快速键入
- Webpack/Rect:遵循egghead.io教程,但出现错误:您可能需要一个合适的加载程序来处理此文件类型
- 提示使用服务器端事件处理程序激活JavaScript
- 将事件处理程序绑定到任何可能的事件
- 正在将事件处理程序添加到不存在的类
- 在AJAX回调和呈现PIXIJS之间处理程序流时遇到了问题
- Adobe Edge:动画完成时添加onComplete处理程序
- 是否可以从输入处理程序中确定输入的类型
- 在MVVM视图模型中处理应用程序范围的元素
- 在循环中附加事件处理程序时出现浏览器性能问题
- 在同一个javascript事件处理程序中调用不同的函数
- 有没有一种方法可以让内联事件处理程序在元素创建后立即执行
- 检查事件处理程序参数
- 实现延迟的jquery更改事件处理程序
- 如何使用Python/Selenium网络驱动程序处理Angularjs/Javascript下拉列表
- 在 AJAX 完成之前,不要让其他处理程序处理
- 如何使用硒铬驱动程序处理地理位置弹出窗口
- 如何使用硒网络驱动程序处理 onblur 事件
- 是否有一种方法为chrome打包应用程序处理Http BasicAuthentication
- Ajax加载程序处理问题