Как сделать jquery автозаполнение элементов списка отзывчивым - PullRequest
0 голосов
/ 31 октября 2018

У меня есть сайт начальной загрузки 4, на котором я реализовал автозаполнение JQuery, но элементы списка автозаполнения jquery не отвечают.

Вот мой код

  jQuery(document).ready(function ($) {
            $(function () {
                $("#autocompSearch").autocomplete({
                    source: function (request, response) {
                        $.ajax({
                            url: "pullDocs.php",
                            type: "POST", dataType: "json",
                            data: { inp: request.term, maxResults: 4 },
                            success: function (data) {
                                response($.map(data, function (result) {
                                    return {
                                        label: "Dr." + result.docName + " - " + result.clinicName + " | " + result.clinicCity,
                                        docId: result.docId,
                                        clinicId: result.clinicUsername,
                                        value: "Dr." + result.docName
                                    }
                                }));
                            }
                        });
                    }
                }).data("ui-autocomplete")._renderItem = function (ul, item) {
                    return $("<li></li>")
                        .data("item.autocomplete", item)
                        .append("<a class='ui-corner-all' style='display:block' href='#' onclick='updateHiddenElement(" + item.docId + "," + item.clinicId + ")'><img width='60' height='60' class='rounded-circle' src='images/docimgforac.jpeg' />&nbsp;" + item.label + "</a>")
                        .appendTo(ul);
                };
            });

        });

Вот мои стили, я попытался добавить width: 200px к .ui-autocomplete, это сделало контейнер автозаполнения отзывчивым, но содержимое внутри тега li не переносится внутри контейнера, текст выходит из контейнера.

 .ui-autocomplete {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 1000;
    float: left;
    display: none;
    min-width: 160px;   
    padding: 4px 0;
    margin: 0 0 10px 25px;
    list-style: none;    
    background-color: #000000; /*   For autocomplete entire list's bg color */
    border-color: #ccc;
    border-color: rgba(0, 0, 0, 0.2);
    border-style: solid;
    border-width: 1px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border-radius: 5px;
    -webkit-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
    -moz-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
    box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
    -webkit-background-clip: padding-box;
    -moz-background-clip: padding;
    background-clip: padding-box;
    *border-right-width: 2px;
    *border-bottom-width: 2px;
}

.ui-menu-item > a.ui-corner-all {
    display: block;
    padding: 3px 15px;
    clear: both;
    font-weight: normal;
    line-height: 18px;
    color: #ffffff;
    white-space: nowrap;
    text-decoration: none;
}

.ui-state-hover, .ui-state-active {
    color: #ffffff;
    text-decoration: none;
    background-color: #0088cc;
    border-radius: 0px;
    -webkit-border-radius: 0px;
    -moz-border-radius: 0px;
    background-image: none;
}
.ui-state-hover, .ui-autocomplete li:hover
{
    color:White;
    background:#ff546c;
    outline:none;
}
.ui-menu-item .ui-menu-item-wrapper:hover
{
    border: none !important;
    background-color: #ff546c;     /*   For autocomplete Li item hover bg color */
}
.ui-helper-hidden-accessible 
{ 
    display:none; 
}

Подскажите, пожалуйста, как обеспечить отзывчивость элементов списка автозаполнения?

1 Ответ

0 голосов
/ 01 ноября 2018

Мне удалось найти решение, я просто вложил элементы списка в div, как показано ниже

.append("<div class='container'><div class='row'><a class='ui-corner-all' style='display:block;' href='#' onclick='updateHiddenElement(" + item.docId + "," + item.clinicId + ")'><img width='60' height='60' class='rounded-circle' src='images/docimgforac.jpeg' />&nbsp;" + item.label + "</a></div></div>")
...