Я пытаюсь сделать "фильтр по выбору" , используя кнопку раскрывающегося списка.
Всякий раз, когда пользователь нажимает на элемент определенного типа (например, одежду в моем примере), в html отображаются только элементы, соответствующие критериям (только одежда). Мне удалось выбрать элементы, которые я хотел, и поместить в массив, однако, когда я пытаюсь заменить div новым массивом, вывод будет [object HTML Element]
.
Забавно, если Я console.log
массив с определенным значением, (array[0])
он показывает HTML-код, который мне нужен.
<div class="dropdown-menu" >
<a class="dropdown-item" onClick="filter('clothes')" >Clothes</a>
<a class="dropdown-item" onClick="filter('electronics')" >Electronics</a>
</div>
<div id="testSearch">
<section name="product">
<img value="clothes" src="./some.jpg" alt="Clothes 01">
<h5>Electronic</h5>
</section>
<section name="product">
<img value="electronics" src="./some2.jpg" alt="Electronics 01">
<h5>Electronic</h5>
</section>
</div>
<!-- My code has different sections with a variety of value/h5 -->
<script>
function filter(x) {
var arraySearch = [];
var input = document.getElementsByName('product');
for (i=0; i < input.length; i++) {
if(input[i].innerHTML.indexOf(x) > 0 ) {
arraySearch[i]= input[i];
result = result + arraySearch[i];
}
}
document.getElementById('testSearch').innerHTML = result;
<!-- my html display only [object HTMLElement], if more than a section matches, then it displays the [object HTMLElement] times the number of sections matched -->
}
</script>
Я ожидаю, что выходные данные объекта [HTMLElement] будут разделами, которые соответствуют критериям.