html, JS список полей поиска - PullRequest
0 голосов
/ 18 февраля 2020

Я новичок в JS, но обладаю хорошими знаниями в C и HTML и хочу создать окно поиска, чтобы при написании чего-либо появлялся раскрывающийся список с некоторыми результатами. У меня уже есть код для создания анимированного поля поиска (которое не принадлежит мне) и код для создания этого списка фильтров поиска, но я не знаю, как их «соединить».

Вот JS часть для фильтра панели поиска: (Чтобы использовать его, вам просто нужен этот html код <input type="text" id="searchInput" placeholder="Search article"/> вот скрипка: https://jsfiddle.net/c30L5esq/)

$("#searchInput").on('keyup', function() {
  var searchValue = $(this).val().toUpperCase();
  if(searchValue.length > 0) {
    searchAndFilter(searchValue);
  } else {
    $("#articlesearch li").hide();
  }
});

function searchAndFilter(searchTerm) {
  $("#articlesearch li").each(function() {
    var currentText = $(this).text().toUpperCase();
    if (currentText.indexOf(searchTerm) >= 0) {
      $(this).show();
    } else {
        $(this).hide();
    }
  });
}

$(document).ready(function() {
  $("#articlesearch li").hide();
});

И вот оно ссылка для полноэкранной анимации панели поиска: https://codepen.io/suez/pen/obpLvy/

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

Спасибо!

Ответы [ 2 ]

1 голос
/ 18 февраля 2020

Я думаю, что вы ищете автозаполнение для поиска. Для этого мы должны использовать typeahead. js плагин. Вы можете go со ссылкой на плагин и Codepen пример ссылки. В ссылке есть несколько примеров demos .

var substringMatcher = function(strs) {
  return function findMatches(q, cb) {
    var matches, substringRegex;

    // an array that will be populated with substring matches
    matches = [];

    // regex used to determine if a string contains the substring `q`
    substrRegex = new RegExp(q, 'i');

    // iterate through the pool of strings and for any string that
    // contains the substring `q`, add it to the `matches` array
    $.each(strs, function(i, str) {
      if (substrRegex.test(str)) {
        matches.push(str);
      }
    });

    cb(matches);
  };
};

var states = ['Alabama', 'Alaska', 'Arizona', 'Arkansas', 'California',
  'Colorado', 'Connecticut', 'Delaware', 'Florida', 'Georgia', 'Hawaii',
  'Idaho', 'Illinois', 'Indiana', 'Iowa', 'Kansas', 'Kentucky', 'Louisiana',
  'Maine', 'Maryland', 'Massachusetts', 'Michigan', 'Minnesota',
  'Mississippi', 'Missouri', 'Montana', 'Nebraska', 'Nevada', 'New Hampshire',
  'New Jersey', 'New Mexico', 'New York', 'North Carolina', 'North Dakota',
  'Ohio', 'Oklahoma', 'Oregon', 'Pennsylvania', 'Rhode Island',
  'South Carolina', 'South Dakota', 'Tennessee', 'Texas', 'Utah', 'Vermont',
  'Virginia', 'Washington', 'West Virginia', 'Wisconsin', 'Wyoming'
];

$('#the-basics .typeahead').typeahead({
  hint: true,
  highlight: true,
  minLength: 1
},
{
  name: 'states',
  source: substringMatcher(states)
});
<div id="the-basics">
  <input class="typeahead" type="text" placeholder="States of USA">
</div>

<script src="https://code.jquery.com/jquery-2.1.4.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/typeahead.js/0.11.1/typeahead.jquery.min.js"></script>
1 голос
/ 18 февраля 2020
$(document).ready(function() {
  var list = $("#articlesearch>li");
  list.hide();

  $(document).on('input', "#searchInput", function() {
    /* searchAndFilter($(this).val()) */
    list.hide();
    var searchTerm = ($(this).val() + '').toUpperCase();
    if (searchTerm.length > 0) {
      list.each(function() {
        var currentText = $(this).text().toUpperCase();
        if (currentText.indexOf(searchTerm) >= 0) {
          $(this).show();
        } else {
          $(this).hide();
        }
      });
    }
  });
});

Jsfiddle: https://jsfiddle.net/ravinila/ghovnzty/13

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