jqueryui автозаполнение держать открытым, но закрывать при нажатии снаружи - PullRequest
0 голосов
/ 26 октября 2018

Я использую автозаполнение jquery-ui.

Я хочу, чтобы список результатов поиска автозаполнения оставался открытым и закрытым, когда область за пределами области ввода текста автозаполнения и списка результатов поиска.

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

Теперь он остается открытым.но не могу узнать, как закрыть его, когда нажата внешняя область.

http://jsfiddle.net/9r3avhoe/6/

$("input").autocomplete({
    source: ["Apple", "Boy", "Cat"],
    minLength: 0,
    response: function(event, ui) {
          //console.log(ui);
        },
        select: function(event, ui) {
          addObject(ui.item.value);
          return false;
        },
        focus: function(event, ui) {
          return false;
        },
        close: function(event, ui) {
          if (!$("ul.ui-autocomplete").is(":visible")) {
            $("ul.ui-autocomplete").show();
            $( "#search" ).focus();
          }

        }
});

Ответы [ 2 ]

0 голосов
/ 26 октября 2018

$("input").autocomplete({
    source: ["Apple", "Boy", "Cat"],
    minLength: 0,
		response: function(event, ui) {
					//console.log(ui);
				},
				select: function(event, ui) {
					addObject(ui.item.value);
					return false;
				},
				focus: function(event, ui) {
        console.log("focused");
					return true;
				},
				close: function(event, ui) {
					if (!$("ul.ui-autocomplete").is(":visible")) {
						$("ul.ui-autocomplete").show();
						$( "#search" ).focus();
					}

				}
});
$( "input").blur(function() {
  	$("ul.ui-autocomplete").hide();
  	
});
function addObject(id){
	var div = $('<p>'+id+'</p>').attr({"value":id}); 

	div.appendTo("#selected_obj");
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.0.2/jquery.min.js"></script>

<script
  src="https://code.jquery.com/ui/1.12.1/jquery-ui.min.js"
  integrity="sha256-VazP97ZCwtekAsvgPBSUwPFKdrwD3unUfSGVYrahUqU="
  crossorigin="anonymous"></script>
<link href="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.css" rel="stylesheet"/>
  <input type="text" />
<br/>
<br/>
<div id="selected_obj" style="border:solid 1px black;float:right">

</div>

Добавьте событие размытия и скройте всплывающее окно.Я надеюсь, что это поможет вам.

0 голосов
/ 26 октября 2018

Вы можете использовать фокусировку и просто вызвать событие виджета.

$("input").focusout(function(event) {
    $("ul.ui-autocomplete").hide();
})
...