Jquery проверки нескольких вкладок, проверить по одной за раз? - PullRequest
12 голосов
/ 13 апреля 2011

Я новичок в jQuery, и я пытаюсь использовать его и плагин проверки (http://docs.jquery.com/Plugins/Validation), чтобы создать форму из нескольких частей с несколькими вкладками для разных разделов. Прямо сейчас у меня есть, где есть несколько вкладок икнопка «Далее» переключается на следующую вкладку.

Проблема, с которой я столкнулся, заключается в том, что при окончательной отправке на последней странице форма корректно проверяется, но если на другой странице есть ошибки, пользователь нене получают уведомления, и проверка действительно происходит только после нажатия кнопки «Отправить».

Как бы я проверил каждую из них по отдельности, когда нажал «Далее»? Я не хочу создавать несколько форм или отслеживать скрытыеполя: S Есть предложения?

Спасибо!

<script type="text/javascript">
$(document).ready(function() {
    //....stuff
    //tabs
    var tabs = $("#tabs").tabs();
    $(".nexttab").click(function() {
        //var selected = $("#tabs").tabs("option", "selected");
        //$("#tabs").tabs("option", "selected", selected + 1);
        $("#tabs").tabs("select", this.hash);
    });

    //use link to submit form instead of button
    $("a[id=submit]").click( function(){
        $(this).parents("form").submit();
    });

    //form validation
    var validator = $("#myForm").validate();    
});
</script>

<form class="cmxform" id="myForm" method="post" action="">
    <div id="tabs">
        <ul>
            <li><a href="#general">General</a></li>
            <li><a href="#tab2"></a></li>
        </ul>

        <div id="general">
             ....stuff...
            <p>
                <a class="nexttab navbutton" href="#tab2"><span>Next</span></a>  
            </p>
        </div>
        <div id="tab2">
            <h2>Tab2</h2>
            <p>
                <a class="nexttab navbutton" href="#general"><span>Prev</span></a>
                <a class="submit navbutton" id="submit" href="#"><span>Submit</span></a>
            </p>
        </div>
    </div>
</form>

Редактировать:

@ Андрей:

Я сделал несколько комбинаций из вашего второго примера и отключилВкладки. Кажется, работает, кроме обновления страницы, снова отключите вкладки.

var tabs = $("#tabs").tabs({

    disabled: [1,2,3,4,5],

    select: function(event, ui) {
        var valid = true;
        var current = $(this).tabs("option", "selected");
        var panelId = $("#tabs ul a").eq(current).attr("href");

        if(ui.index > current)
        {
            $(panelId).find("input").each(function() {
                //console.log(valid);

                if (!validator.element(this) && valid) {
                    valid = false;
                }
            });

        }

        return valid;
    }   

});

В сочетании с:

$(".nexttab").click(function() {
    var selected = $("#tabs").tabs("option", "selected");
    $("#tabs").tabs("enable", selected+1);
    $("#tabs").tabs("option", "selected", selected + 1);
});

Ответы [ 2 ]

11 голосов
/ 13 апреля 2011

Это возможно при использовании функции .element(selector), равной validator. То, что вы собираетесь сделать, это перебрать каждый элемент на активной вкладке и вызвать эту функцию на входе. Это будет запускать проверку каждого элемента по очереди, показывая сообщение проверки.

$(".nexttab").click(function() {
    var valid = true;
    var i = 0;
    var $inputs = $(this).closest("div").find("input");

    $inputs.each(function() {
        if (!validator.element(this) && valid) {
            valid = false;
        }
    });

    if (valid) {
        $("#tabs").tabs("select", this.hash);
    }
});

Кроме того, вы, вероятно, захотите запустить подобный код, когда пользователь нажимает на вкладку, чтобы перейти к новому набору входных данных, вместо нажатия «Далее».

Вот рабочий пример: http://jsfiddle.net/c2y6r/

Обновление: Вот еще один способ сделать это, отменив событие select для недопустимых элементов формы:

var validator = $("#myForm").validate();
var tabs = $("#tabs").tabs({
    select: function(event, ui) {
        var valid = true;
        var current = $(this).tabs("option", "selected");
        var panelId = $("#tabs ul a").eq(current).attr("href");

        $(panelId).find("input").each(function() {
            console.log(valid);
            if (!validator.element(this) && valid) {
                valid = false;
            }
        });

        return valid;
    }
});

Однако теперь вам нужно подумать о том, чтобы разрешить пользователю вернуться, когда он ввел недействительные данные на текущей странице. С другой стороны, вы получаете бонус за хранение всего кода проверки внутри одной функции, которая срабатывает, если человек нажимает на вкладку или следующую ссылку.

Пример: http://jsfiddle.net/c2y6r/1/

Обновление 2 , если вы хотите, чтобы люди могли перемещаться назад через интерфейс вкладки:

var tabs = $("#tabs").tabs({
    select: function(event, ui) {
        var valid = true;
        var current = $(this).tabs("option", "selected");
        var panelId = $("#tabs ul a").eq(current).attr("href");

        if (ui.index > current) {

            $(panelId).find("input").each(function() {
                console.log(valid);
                if (!validator.element(this) && valid) {
                    valid = false;
                }
            });
        }

        return valid;
    }
});
0 голосов
/ 01 сентября 2017

Существующий код не работает для меня (возможно, он устарел), поэтому я придумал следующее.В этом примере предполагается использование вкладок jquery и валидатора jquery.

$('#tabs').tabs(
{
    beforeActivate: function( event, ui )
    {   
        var valid = $("#myForm").valid();
        if (!valid) {
            validator.focusInvalid();
            return false;
        }
        else
            return true;
    }
});
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...