изменение и проверка JQuery - PullRequest
       18

изменение и проверка JQuery

3 голосов
/ 23 сентября 2011

У нас есть поле ввода автозаполнения jquery:

<input name="suburb" id="suburb-agency" autocomplete="off" class="text" type="text" value="">

Это выпадает, и когда они выбирают опцию, обновляется другое поле выбора в зависимости от того, что было выбрано:

<select class="text" name="state" id="state-agency">
    <option value="notselected">Please select your state...</option>
    <option value="Apple">Apple</option>
    <option value="Pear">Pear</option>
</select>

Скажем, например, они выбирают Грушу в автозаполнении #suburb-agency, затем Груша выбирается автоматически в #state-agency

Это прекрасно работает.

Единственная проблема, с которой я сталкиваюсь, - это проверка jquery, при выборе Pear и изменении поля #state-agency проверка не отображается, хотя и появляется, если я вручную выбираю параметр в раскрывающемся списке.

Вот мой jquery:

/* STATE VALIDATION */
    $("#state-agency").change(function () {
        var state = $('#state-agency').val();
        if (state == "notselected"){
            $('#state-agency').css({"border-color":"#3399ff"});
            $('#state-err').html("You must choose which state you work in.").removeClass("success_msg").addClass("error_msg");
            return false;
        }else{
            $('#state-agency').css({"border-color":"#1f6d21"});
            $('#state-err').html("Thanks for choosing your state!").removeClass("error_msg").addClass("success_msg");
        }
    });

Как я могу изменить это, чтобы оно показывало сообщение об успехе, если оно выбрано из автозаполнения? а не только вручную? Я предполагаю, что мне нужно перейти с change function?

Редактировать (наш код автозаполнения, который обновляет выпадающий список по запросу)

$(function() {
    function split( val ) {
        return val.split( /,\s*/ );
    }
    function extractLast( term ) {
        return split(term).pop();
    }

    $( "#suburb-agency" )
        // don't navigate away from the field on tab when selecting an item
        .bind( "keydown", function( event ) {
            if ( event.keyCode === $.ui.keyCode.TAB &&
                    $( this ).data( "autocomplete" ).menu.active ) {
                event.preventDefault();
            }
        })
        .autocomplete({
            source: function( request, response ) {
                $.getJSON( "http://www.site.com/folder/script.php", {
                    term    :   extractLast( request.term )
                }, response );
            },
            search: function() {
                // custom minLength
                var term = extractLast( this.value );
                if ( term.length < 2 ) {
                    return false;
                }
            },
            focus: function() {
                // prevent value inserted on focus
                return false;
            },
            select: function( event, ui ) {
              if (ui.item) {
                $('#state-agency').val(ui.item.state);
              }
              else {
                $('#state-agency').val('');
              }
            }
        });
});

Ответы [ 2 ]

0 голосов
/ 25 сентября 2011

Я нашел исправление для этого, мне нужно было использовать trigger() для соответствующих идентификаторов в автозаполнении JS.

0 голосов
/ 24 сентября 2011

Если вы используете проверку jQuery, чтобы выполнить проверку элемента ввода после того, как вы обновили его, вам нужно вызвать

 $(selector).valid()
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...