自分用Javascript_部分一致でQAシート

<html>

<head>
<meta charset="UTF-8">
<link rel="stylesheet" href="style.css">
<title>QA</title>
</head>

<body>
<input type="text" id="myInput" onkeyup= "myFunction()" placeholder="検索ワード">
<ul id="myUL">
<li><a href="#">あいうえお</a></li>
<li><a href="#">かきくけこ</a></li>
</ul>

<style>
#myInput{
background-position:10px 12px
background-repeat: none;
width: 80%;
font-size: 8px;
padding:12px 20px 12px 40px;
border:1px solid:#ddd
margin-top: 8px;
margin-bottom: 12px;
}

#myUL{
list-style-type: none;
padding: 0;
margin: 0;
}
ul#myUL li {
padding: 0;
}

#myUL li a {
border: 1px solid #ddd;
margin-top: -1px;
background-color: #f6f6f6;
padding: 12px;
text-decoration: none;
font-size: 14px;
color: black;
display: block;
word-wrap: nomal;
}
#myUL li a:hover:not(.header) {
background-color: #c8e4ff;
</style>


<script>
function myFunction(){
var input, filter, ul, li, a, i, txtValue;
input = document.getElementById('myInput');
filter = input.value.toUpperCase();
ul = document.getElementById("myUL");
li = ul.getElementsByTagName('li');

for (i = 0; i < li.length; i++) {
a = li[i].getElementsByTagName("a")[0];
txtValue = a.textContent|| a.innerText;

if
(txtValue.toUpperCase().indexOf(filter) > -1){
li[i].style.display = "";
} else {
li[i].style.display = "none";
}
}
}

</script>
</body>
</html>

細かいCSSは置いておいて、
<li><a href="#">あいうえお</a></li>
<li><a href="#">かきくけこ</a></li>
の部分を増やす面倒はあるが、増やしてから上記検索になにか入れると部分一致で拾ってくれる。

この記事が気に入ったらサポートをしてみませんか?