-1

我有几个选项卡,从数据库填充。每个选项卡都包含一个部分视图,也是从数据库中填充的。当有人向这些部分代表的集合之一添加某些内容时,我希望它刷新选项卡内容,以反映更改。

function addNewRequest(arForm) {
    username = $(".ui-tabs-selected").attr("id");
    currentUser = document.getElementById("currUser").value;
    $.ajax({
        url: 'Home/submitAdvisoryRequestForm',
        type: 'POST',
        data: arForm.serialize() + "&username=" + username + "&currUser=" + currentUser,
        success: function (response) {
            if (response == "true") {
                $("#users").tabs("load", $('#users .ui-tabs-panel:not(.ui-tabs-hide)').index() - 1);
                dialog.dialog("close");
            } else {
                alert(response);
            }
        },
        error: function (xhr, ajaxOptions, thrownError) { alert(xhr.status); alert(thrownError); }
    });

}

因此,据我了解,如果 ajax 调用成功,它将尝试在当前选定的索引处加载选项卡。我看过用于抓取所选标签索引的表达式,据我所知,它有效,即使可能有点hacky。

应该刷新选项卡的代码,$("#users").tabs("load", $('#users .ui-tabs-panel:not(.ui-tabs-hide)').index() - 1);,什么都不做。有谁知道为什么?

4

1 回答 1

0

F**kadoodle-doo,我想通了。因为 JQueryUI 很蹩脚,只允许你刷新 AJAX 加载的内容,所以只替换当前选定选项卡的 div 的 HTML 会更容易。

jQuery代码:

function addNewRequest(arForm) {
    username = $(".ui-tabs-selected").attr("id");
    currentUser = document.getElementById("currUser").value;
    $.ajax({
        url: 'Home/submitAdvisoryRequestForm',
        type: 'POST',
        data: arForm.serialize() + "&username=" + username + "&currUser=" + currentUser,
        success: function (response) {
            if (response) {
                $('#users .ui-tabs-panel:not(.ui-tabs-hide)').html(response);
                dialog.dialog("close");
            } else {
                alert(response);
            }
        },
        error: function (xhr, ajaxOptions, thrownError) { alert(xhr.status); alert(thrownError); }
    });
}

作为回应,将部分观点放在它上面。

public ActionResult submitAdvisoryRequestForm(BCRTAdvisoryRequest newRequest, string username, string currUser)
{
    if (ModelState.IsValid)
    {
        var ar = new AdvisoryRequestsLogic();
        if (ar.addAdvisoryRequest(newRequest) > 0)
            return PartialView("_userAdvisoryRequests", ar.getUserAdvisoryRequests(username));
    }
    return null;
}
于 2014-08-07T17:24:24.407 回答