Beispiel:JS-Suche-1.html

Aus SELFHTML-Wiki
Wechseln zu: Navigation, Suche

<!DOCTYPE html> <html lang="de"> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0" > <link rel="stylesheet" media="screen" href="./Beispiel:Grundlayout.css"> <title>Suchen und Filtern</title>

<style> body {

 max-width: 50em;
 background: black;
 color: white !important;

} img {

 max-width: 50%;
 float: right;
 margin: 0 0 1em 1em;

} h1 {

 color: gold;

} article {

 padding: 1em;

} article:after { /*clearfix */

 content: "";
 display: block;
 clear: both;

} .active {

 background: #337599;

} .is-hidden {

 display: none;

} </style>

<script>

 document.addEventListener('DOMContentLoaded', function () {
 // Das Formular, das Suchfeld und alle Artikel werden einmalig gesucht.
 const searchForm = document.querySelector('form');
 const searchInput = document.querySelector('#search');
 const articles = document.querySelectorAll('article');
 // Suchtexte werden vereinheitlicht: Leerzeichen am Rand entfernen und Kleinschreibung nutzen.
 function normalize(text) {
   return text.trim().toLocaleLowerCase('de-DE');
 }
 // Für jeden Artikel wird ein kompletter Suchtext zusammengestellt.
 function getSearchText(article) {
   // Die Alternativtexte der Bilder werden gesammelt, damit auch Bildinhalte gefunden werden können.
   let imageTexts = Array.from(article.querySelectorAll('img'))
     .map(function (image) {
       return image.alt;
     })
     .join(' ');
   // Die Artikel-ID, der sichtbare Text und die Alternativtexte bilden zusammen die Suchbasis.
   return normalize(article.id + ' ' + article.innerText + ' ' + imageTexts);
 }
 // Alle Artikel werden anhand des aktuellen Suchbegriffs ein- oder ausgeblendet.
 function filterArticles() {
   // Auch die Eingabe aus dem Suchfeld wird vor dem Vergleich vereinheitlicht.
   let searchQuery = normalize(searchInput.value);
   articles.forEach(function (article) {
     // Ohne Suchbegriff bleiben alle Artikel sichtbar.
     // Sonst bleibt nur sichtbar, was den Suchbegriff in der Suchbasis enthält.
     let isRelevant = !searchQuery || getSearchText(article).includes(searchQuery);
     article.classList.toggle('is-hidden', !isRelevant);
   });
 }
 // Beim Tippen wird die Suche leicht verzögert, damit nicht nach jedem Tastendruck sofort gefiltert wird.
 let typingTimer;
 let typeInterval = 500;
 // Neue Eingaben brechen eine noch wartende Suche ab und starten die Suche neu.
 function queueFilter() {
   clearTimeout(typingTimer);
   // Wenn das Suchfeld leer ist, werden alle Artikel sofort wieder angezeigt.
   if (!normalize(searchInput.value)) {
     filterArticles();
     return;
   }
   // Bei normaler Eingabe wird erst nach einer kurzen Pause gesucht.
   typingTimer = setTimeout(filterArticles, typeInterval);
 }
 // Das input-Ereignis erfasst Tippen, Einfügen und viele Browseraktionen im Suchfeld.
 searchInput.addEventListener('input', queueFilter);
 // Das change-Ereignis erfasst unter anderem die Auswahl aus der Datalist.
 searchInput.addEventListener('change', filterArticles);
 // Das search-Ereignis erfasst das Leeren über das Kreuz im Suchfeld, wo der Browser es anbietet.
 searchInput.addEventListener('search', filterArticles);
 // Das Formular soll die Seite nicht neu laden, sondern nur die vorhandene Live-Suche ausführen.
 searchForm.addEventListener('submit', function (event) {
   event.preventDefault();
   filterArticles();
 });

}); </script> </head>

<body>

Suchen und Filtern

<form action="#">

 <label for="search">Vogelpark</label>
 <input type="search" id="search" list="vogelparks">
 <datalist id="vogelparks">
   <option value="de10319">10319 Berlin</option>
   <option value="de10787">10787 Berlin</option>
   <option value="de14109">14109 Berlin</option>
   <option value="de15837">15837 Baruth/Mark</option>
   <option value="de16225">16225 Eberswalde</option>
   <option value="de17373">17373 Ueckermünde</option>
   <option value="de17489">17489 Greifswald</option>
   <option value="de18273">18273 Güstrow</option>
   <option value="de18337">18337 Marlow</option>
   <option value="de19061">19061 Schwerin</option>
 </datalist>

</form>

<article id="de10319">

Tierpark Berlin

<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/3/32/Sagittarius_serpentarius_%28Tierpark_Berlin%2C_2008%29.jpg/960px-Sagittarius_serpentarius_%28Tierpark_Berlin%2C_2008%29.jpg" alt="Sekretärvogel im Tierpark Berlin"> Am Tierpark 125 10319 Berlin

</article>

<article id="de10787">

Zoologischer Garten Berlin AG

<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/2/2f/Glaucidium_perlatum_Berlin_Zoo.jpg/500px-Glaucidium_perlatum_Berlin_Zoo.jpg" alt="Eule im Zoologischen Garten in Berlin"> Hardenbergplatz 8 10787 Berlin
<img src="https://wiki.selfhtml.org/images/thumb/f/f1/Flamingo_Winter_Zoologischer_Garten_Berlin_cropped.jpg/800px-Flamingo_Winter_Zoologischer_Garten_Berlin_cropped.jpg" alt="Flamingos im Winter">

</article>

<article id="de14109">

Pfaueninsel

<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/d/d7/Pfaueninsel-7712.jpg/960px-Pfaueninsel-7712.jpg" alt="Pfau schlägt Rad"> Nikolskoer Weg 14109 Berlin

</article>

<article id="de15837">

Wildpark Johannismühle

<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/1/10/TF_Wildpark_Johannismuehle_03-14_img11.jpg/960px-TF_Wildpark_Johannismuehle_03-14_img11.jpg" alt="Wüstenbussard im Wildpark Johannismühle"> Johannismühle 2 15837 Baruth/Mark

</article>

<article id="de16225">

Zoologischer Garten Eberswalde

<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/0/09/Grünflügelara_Eberswalder_Zoo.jpg/960px-Grünflügelara_Eberswalder_Zoo.jpg" alt="Grünflügelaras in Eberswalde"> Am Wasserfall 1 16225 Eberswalde

</article>

<article id="de17373">

Tierpark Ueckermünde

<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/4/40/Aix_galericulata_in_Tierpark_Ueckermünde.JPG/960px-Aix_galericulata_in_Tierpark_Ueckermünde.JPG" alt="Mandarinente"> Chausseestraße 76 17373 Ueckermünde

</article>

<article id="de17489">

Heimattierpark Hansestadt Greifswald

<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/7/73/Gooses_at_afternoon.jpg/960px-Gooses_at_afternoon.jpg" alt="Gänse in der Sonne"> Anlagen 3 17489 Greifswald

</article>

<article id="de18273">

Natur- und Umweltpark Güstrow

<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/4/42/Uhu_im_Wildpark-MV.jpg/960px-Uhu_im_Wildpark-MV.jpg" alt="Uhu"> Verbindungschaussee 1 18273 Güstrow

</article>

<article id="de18337">

Erlebnis Vogelpark Marlow gGmbH

<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/7/7c/Vogelpark_Marlow_-_Loris_-_Trio.jpg/960px-Vogelpark_Marlow_-_Loris_-_Trio.jpg" alt="Loris im Vogelpark Marlow"> Kölzower Chaussee 1 18337 Marlow

</article>

<article id="de18546">

Tierpark Sassnitz

<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/6/6f/TierparkSAS04.jpg/960px-TierparkSAS04.jpg" alt="Rotmilan"> 18546 Sassnitz

</article>

<article id="de19061">

Zoo Schwerin

<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/7/7d/Circles_%286993162298%29.jpg/960px-Circles_%286993162298%29.jpg" alt="Siebenauge"> An der Crivitzer Chaussee 1 19061 Schwerin

</article>

<article id="de22527">

Tierpark Hagenbeck

<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/7/77/Carl_Hagenbeck.jpg/960px-Carl_Hagenbeck.jpg" alt="hagenbeck"> Lokstedter Grenzstraße 2 22527 Hamburg

</article>

<article id="de23669">

Vogelpark Niendorf

<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/7/70/20190511151838_IMG_0904.jpg/960px-20190511151838_IMG_0904.jpg" alt="Hahn im Vogelpark Niendorf"> An der Aalbeek 23669 Timmendorfer Strand / Niendorf

</article>

<article id="de24214">

Tierpark Gettorf

<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/0/0c/052_Riesentukan_%28Gettorf_1982%29_%2815553325690%29.jpg/960px-052_Riesentukan_%28Gettorf_1982%29_%2815553325690%29.jpg" alt="Tukan im Tierpark Gettorf"> Süderstr. 33 24214 Gettorf

</article>

<article id="de25826">

Tierpark Westküstenpark

<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/2/23/Klappernde_Störche.jpg/960px-Klappernde_Störche.jpg" alt="klappernde Störche im Westküstenpark"> Wohldweg 6 25826 St. Peter-Ording

</article>

<article id="de26349">

Jaderpark

<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/1/1e/Pelikan_%28rosa%29.jpg/960px-Pelikan_%28rosa%29.jpg" alt="Pelikan im Jaderpark"> Tiergartenstr. 69 26349 Jaderberg

</article>

<article id="de27568">

Zoo am Meer Bremerhaven

<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/a/a4/Zoo_am_Meer_2008_PD_37.JPG/960px-Zoo_am_Meer_2008_PD_37.JPG" alt="Pinguine, Zoo am Meer, Bremerhaven"> H.-H.-Meier-Straße 7 27568 Bremerhaven

</article>

<article id="de29646">

Greifvogel-Gehege Bispingen

<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/7/7d/Eagle_Owl_IMG_9203.JPG/960px-Eagle_Owl_IMG_9203.JPG" alt="Eule"> An der Bundesstraße 209 29646 Bispingen

</article>

<article id="de29693">

Serengeti-Park Hodenhagen

<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/e/ed/Balearica_regulorum_-_Serengeti-Park_Hodenhagen_2017_03.jpg/960px-Balearica_regulorum_-_Serengeti-Park_Hodenhagen_2017_03.jpg" alt="Südafrika-Kronenkraniche"> Am Safaripark 1 29693 Hodenhagen

</article>

<article id="de29664">

Vogelpark Walsrode

<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/a/ab/Vogelpark_Walsrode_2012_%28040%29.jpg/960px-Vogelpark_Walsrode_2012_%28040%29.jpg" alt="Tukan im Vogelpark Walsrode"> Am Vogelpark 29664 Walsrode Tipp

</article>

</body> </html>