среда, 5 июля 2017 г.

JavaScript. Практика. Фильтрация на сайте.

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";
        }
    }
}

Комментариев нет:

Отправить комментарий