index.html
Событие onkeyup возникает в момент отпускания нажатой клавиши.
<!DOCTYPE HTML>
<html lang="en-US">
<head>
<meta charset="UTF-8">
<title>Фильтрация на сайте</title>
<link rel="stylesheet" href="style.css" />
</head>
<body>
<input type="text" onkeyup="myFunction()" id="myInput" placeholder="Search for names"/>
<ul id="myUl">
<li><a href="" class="header">A</a></li>
<li><a href="">Anton</a></li>
<li><a href="">Andrey</a></li>
<li><a href="" class="header">B</a></li>
<li><a href="">Bogdan</a></li>
<li><a href="">Bill</a></li>
<li><a href="">Boris</a></li>
<li><a href="" class="header">C</a></li>
<li><a href="">Calvin</a></li>
<li><a href="">Christina</a></li>
</ul>
<script src="script.js"></script>
</body>
</html>
style.css
#myInput {
width: 100%;
font-size: 16px;
padding: 12px 20px 12px 5px;
border: 1px;
margin-bottom: 12px;
}
#myUl {
list-style: none;
padding: 0;
margin: 0;
}
#myUl li a {
border: 1px solid #ddd;
margin-top: -1px;
background-color: #f6f6f6;
padding: 12px;
text-decoration: none;
font-size: 18px;
color: black;
display: block;
}
#myUl li a.header {
background-color: #e2e2e2;
cursor: default;
}
#myUl li a:hover {
background-color: #eee;
}
script.js
function myFunction() {
var input, filter, ul, li, a, i;
input = document.getElementById('myInput');
filter = input.value.toUpperCase(); // toUpperCase - все символы строки переводит в верхний регистр.
ul = document.getElementById('myUl');
li = ul.getElementsByTagName('li');
for(i=0; i<li.length; i++) {
a = li[i].getElementsByTagName("a")[0];
// Свойство innerHTML позволяет получить и изменить текст элемента.
/*
Метод indexOf осуществляет поиск подстроки (указывается первым параметром) в строке.
Метод вернет позицию первого совпадения, а если оно не найдено - то -1.
Вторым параметром (он необязателен) можно передать номер символа, откуда следует начинать поиск.
Метод чувствителен к регистру символов.
*/
if(a.innerHTML.toUpperCase().indexOf(filter) > -1) {
li[i].style.display = "";
} else {
li[i].style.display = "none";
}
}
}
Комментариев нет:
Отправить комментарий