我在 div 元素中调用了 Ajax.BeginForm,所以我想获取表单所在的 div 元素。即我想要一个等价于
function function1(event){
var table = $(event.target).parents("table");
}
可以从 Ajax.beginform 的 onsuccess 函数中使用。有人可以在这里帮忙吗?
我在 div 元素中调用了 Ajax.BeginForm,所以我想获取表单所在的 div 元素。即我想要一个等价于
function function1(event){
var table = $(event.target).parents("table");
}
可以从 Ajax.beginform 的 onsuccess 函数中使用。有人可以在这里帮忙吗?
事实证明,在 onsuccess 函数中,“this”指的是表单元素。所以我可以很容易地使用,
$(this).find("mydiv");
或者
$(this).parent("table").find("mydiv");
MVC4 似乎打破了它。可怕的“这个”现在是 XHR。要解决此问题,请使用这个讨厌的 hack:
$(function() {
var lastEvent = null;
$("body").on("submit", "form[data-ajax=true]", function(e) {
lastEvent = e;
});
window.TagXhrWithEventTarget = function(xhr) {
xhr.capturedSubmitEvent = lastEvent;
}
});
并以开始形式:
@using (Ajax.BeginForm("MyAction", "MyController", new AjaxOptions
{
HttpMethod = "POST",
OnSuccess = "ProcessResponse",
OnBegin = "TagXhrWithEventTarget"
}
然后在 ProcessResponse 中:
function ProcessResponse(data, status, xhr) {
var e = xhr.capturedSubmitEvent;
var control = e.target;
. . .