it-roy-ru.com

Автозаполнение применения значения, а не метки для текстового поля

У меня проблемы с попыткой заставить автозаполнение работать должным образом.

Все это выглядит нормально для меня, но ....

<script>
$(function () {
    $("#customer-search").autocomplete({
        source: 'Customer/GetCustomerByName',
        minLength: 3,
        select: function (event, ui) {
            $("#customer-search").val(ui.item.label);
            $("#selected-customer").val(ui.item.label);
        }
    });
});
</script>
<div>
<input id="customer-search" />
 </div>
@Html.Hidden("selected-customer")

Однако, когда я выбираю элемент из выпадающего списка, значение применяется к текстовому полю, а не к метке.

Что я сделал не так?

Если я посмотрю на источник с помощью firebug, то увижу, что мое скрытое поле обновляется правильно.

81
Diver Dan

Поведение по умолчанию для события select заключается в обновлении input с помощью ui.item.value. Этот код запускается после вашего обработчика событий.

Просто верните false или вызовите event.preventDefault(), чтобы предотвратить это. Я также рекомендовал бы сделать нечто подобное для события focus, чтобы ui.item.value не помещался в input, когда пользователь наводит курсор на выбор:

$("#customer-search").autocomplete({
    /* snip */
    select: function(event, ui) {
        event.preventDefault();
        $("#customer-search").val(ui.item.label);
        $("#selected-customer").val(ui.item.label);
    },
    focus: function(event, ui) {
        event.preventDefault();
        $("#customer-search").val(ui.item.label);
    }
});

Пример: http://jsfiddle.net/andrewwhitaker/LCv8L/

199
Andrew Whitaker

Просто хотел бы добавить, что вместо ссылки на элемент ввода "id" внутри выбрать а также фокус функции обратного вызова, которые вы можете использовать этот селектор, как:

$(this).val(ui.item.label);

это полезно, когда вы назначаете автозаполнение для нескольких элементов, то есть по классам:

$(".className").autocomplete({
...
    focus: function(event, ui) {
        event.preventDefault();
        $(this).val(ui.item.label);
    }
});
15
Vlad

В моем случае мне нужно записать другое поле 'id' в скрытом вводе. Поэтому я добавляю еще одно поле в данные, возвращаемые из вызова ajax.

{label:"Name", value:"Value", id:"1"}

И добавили ссылку "Создать новое" внизу списка. При нажатии на кнопку "Создать новый" появится модальное окно, и вы сможете создать новый элемент оттуда.

$('#vendorName').autocomplete
    (
        {
            source: "/Vendors/Search",
            minLength: 2,
            response: function (event, ui)
            {
                ui.content.Push
                ({
                    label: 'Add a new Name',
                    value: 'Add a new Name'
                });
            },
            select: function (event, ui)
            {
                $('#vendorId').val(ui.item.id);
            },
            open: function (event, ui)
            {
                var createNewVendor = function () {
                    alert("Create new");
                }
                $(".ui-autocomplete").find("a").last().attr('data-toggle', 'modal').addClass('highLight');
                $(".ui-autocomplete").find("a").last().attr('href', '#modal-form').addClass('highLight');
            }
        }
    );

Я думаю, дело в том, что вы можете добавить любое дополнительное поле данных, кроме "label" и "value".

Я использую bootstrap модально, и это может быть как ниже:

<div id="modal-form" class="modal fade" aria-hidden="true">
<div class="modal-dialog">
    <div class="modal-content">
        <div class="modal-body">
            <div class="row">

            </div>
        </div>
    </div>
</div>
7
Yang Zhang