• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Filter - wykluczanie

Object Storage Arubacloud
0 głosów
115 wizyt
pytanie zadane 17 stycznia 2019 w JavaScript przez ayo1001 Obywatel (1,890 p.)

Cześć,

Mam taki skrypt do filtrowania po tagach:

link

Jak zrobić w nim wykluczanie? W tym momencie działa, że jeżeli znajdzie szukany tag to go pokazuje, a jak zrobić, żeby np. po zaznaczeniu "Blue" i "Green" pokazało tylko jedną wartość, która spełnia oba warunki?

1 odpowiedź

0 głosów
odpowiedź 18 stycznia 2019 przez pablop76 VIP (123,120 p.)

Coś udało mi się stworzyć, ale nie jestem do tego przekonany. Mimo wszystko jakiś trop

<form id="filter-options">
    <fieldset>
      <legend>filter item</legend>
      <label for="red">red</label>
      <input type="checkbox" id="red">
      <label for="green">green</label>
      <input type="checkbox" id="green">
      <label for="blue">blue</label>
      <input type="checkbox" id="blue">
      <label for="orange">orange</label>
      <input type="checkbox" id="orange">
      <label for="yellow">yellow</label>
      <input type="checkbox" id="yellow">
      </fieldset>
  </form>


<ul id="product-list">
  <li class="red">
    <h2>Red Fire Truck</h2>
  </li>
  <li class="blue">
    <h2>Blue Kite</h2>
  </li>
  <li class="green blue">
    <h2>Green & Blue Parot</h2>
  </li>
  <li class="yellow">
    <h2>Yellow Canary</h2>
  </li>
</ul>
ul{
  list-style: none;
}

label{
  margin-left: 20px;
}
const form = document.getElementById("filter-options");
const input = [...form.querySelectorAll('input')];
const product = document.getElementById("product-list");
const productItems = [...product.querySelectorAll('li')];
//funkcja zwaraca stringa z id zaznaczonych inputów
function inputCheckedId(arrayInput){
  const checkedInput = [];
    arrayInput.forEach(function(el){
    if(el.checked){
      checkedInput.push(el.id);
    }
  })
  return checkedInput.join(" ");
}
form.addEventListener('input',function(){
  //pętla po elementach li porównuje ich klasy (jako string) ze stringiem stworzonym z id inputów
  productItems.forEach(function(el){
  if( el.classList.value == inputCheckedId(input)) {
   el.style.color= "red";
  }
    else{
      el.style.color = "black";
    }
});
});

 

Podobne pytania

0 głosów
2 odpowiedzi 121 wizyt
pytanie zadane 23 grudnia 2018 w JavaScript przez Bakr Mądrala (6,850 p.)
0 głosów
2 odpowiedzi 333 wizyt
pytanie zadane 11 lutego 2018 w JavaScript przez macik1423 Początkujący (480 p.)
0 głosów
0 odpowiedzi 571 wizyt
pytanie zadane 4 grudnia 2018 w Systemy operacyjne, programy przez Shiro Stary wyjadacz (10,300 p.)

92,555 zapytań

141,403 odpowiedzi

319,553 komentarzy

61,939 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...