带有服务器端验证的 jQuery 选项卡向导

发布于 2024-11-08 02:01:09 字数 1733 浏览 5 评论 0原文

我在 Asp.Net MVC 3 网站中利用 jQuery UI 选项卡创建了一个“签出”向导。向导中的每个选项卡都会加载包含表单的部分视图。如果表单有效,我将发布表单数据并将其保存到数据库中。

目前,我可以检查客户端验证,如果当前选项卡无效,则使用此处描述的方法单击下一个或上一个按钮时阻止选择下一个/上一个选项卡 http://jqueryui.com/demos/tabs/#...prevent_switching_to_the_tab_on_click_depending_on_form_validation

但是,并非所有验证都可以在客户端完成,因为我们需要执行一些服务器端检查。因此,如果选项卡通过了客户端验证,那么我会提交表单并检查从服务器返回的响应。如果服务器端验证通过,则返回空字符串,但如果失败,我会返回该选项卡的相同部分视图。

这是我的 jQuery UI 选项卡选择器中的 select 函数:

select: function (event, ui) {

            var checkOutTabs = $(".checkout-tabs").tabs();
            var currentTabIndex = checkOut.getSelectedTabIndex();
            var currentTab = $(".checkout-step").get(currentTabIndex);

            var isValid = checkOut.validateTab(currentTab, ui.index);

            //prevent tab change
            if (!isValid) {
                return false;
            }

            var form = $(currentTab).find("form");

            //Submit this tab
            $.post(form.attr("action"), form.serialize(), function (data) {

                if (!data) {
                    checkOutTabs.tabs("enable", ui.index + 1);
                    return true;
                } else {
                    $(currentTab).find(".checkout-step").parent().html(data);
                    return false;
                }

            });
        }

我遇到的问题是,一旦我调用 jQuery $.post() 方法,选项卡就会切换到下一个选项卡,无论我返回 true 还是 false。我发现一篇文章( Better Way to Build jQuery Tabs )正在做类似的实施,但他们没有报告有这个问题。我做错了什么,还是这是预期的行为?

I have created a Check Out wizard utilizing the jQuery UI Tabs in an Asp.Net MVC 3 website. Each tab in the wizard loads a partial view containing a form. If the form is valid, I post the form data and save it to the database.

Currently I am able to check the client-side validation and if the current tab is not valid, prevent the next/previous tab from being selected when the next or previous button is clicked using the method described here http://jqueryui.com/demos/tabs/#...prevent_switching_to_the_tab_on_click_depending_on_form_validation.

However, not all of the validation can be done client-side as we need to perform some server side checks. So if a tab passes the client-side validation, then I submit the form and check the response returned from the server. If server-side validation passes an empty string is returned, but if it fails I return the same partial view for that tab.

Here is the select function in my jQuery UI Tabs selector:

select: function (event, ui) {

            var checkOutTabs = $(".checkout-tabs").tabs();
            var currentTabIndex = checkOut.getSelectedTabIndex();
            var currentTab = $(".checkout-step").get(currentTabIndex);

            var isValid = checkOut.validateTab(currentTab, ui.index);

            //prevent tab change
            if (!isValid) {
                return false;
            }

            var form = $(currentTab).find("form");

            //Submit this tab
            $.post(form.attr("action"), form.serialize(), function (data) {

                if (!data) {
                    checkOutTabs.tabs("enable", ui.index + 1);
                    return true;
                } else {
                    $(currentTab).find(".checkout-step").parent().html(data);
                    return false;
                }

            });
        }

The problem I am having is that as soon as I call the jQuery $.post() method, the tabs switch to the next tab, regardless of wether I return true or false. I found a post ( Better Way to Build jQuery Tabs ) that is doing a smiliar implementation, but they didn't report having this issue. Am I doing something wrong, or is this the expected behavior?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

So要识趣 2024-11-15 02:01:09

$.post 立即返回,因为它是异步的

,也许您必须阻塞(在 $.ajaxOptions 或其他内容中使用 async = false )直到获得响应,然后通过更改范围更广的变量返回您想要的内容

$.post returns immediately as it's asynchronous

maybe you have to block (using async = false in $.ajaxOptions or something) until response is get, then return what you want by changing a broader-scoped variable

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文