Heim Web-Frontend CSS-Tutorial Verwenden Sie reines CSS, um die Filtermenüfunktion zu implementieren

Verwenden Sie reines CSS, um die Filtermenüfunktion zu implementieren

Dec 13, 2017 pm 01:38 PM
css 功能

In diesem Artikel verwenden wir reines CSS, um den gleichen Effekt wie das Babyfiltermenü von Taobao zu erzielen. Das Prinzip ist jedoch ähnlich Wirkung wie Taobao. Ich hoffe, es hilft allen.

Inhaltsfilterung ist eine gängige Funktion im Web, insbesondere auf E-Commerce-Websites. Sie ermöglicht es Benutzern, Inhalte zu filtern und nur Inhalte anzuzeigen, die ihren Anforderungen entsprechen. Ein Screenshot kann diese Funktion besser veranschaulichen, z. B. Taobao:


Verwenden Sie reines CSS, um die Filtermenüfunktion zu implementieren



Wie im Bild oben gezeigt, möchte der Benutzer ein Kleid kaufen. In der gesamten Produktliste werden zu viele Produkte angezeigt. Kunden wissen nicht, wie sie das gewünschte Kleid auswählen sollen. Oben wird eine Kategorie bereitgestellt. Kunden wählen die von ihnen benötigten Optionen aus und die Produkte, die die Bedingungen nicht erfüllen, werden herausgefiltert. Im Bild oben habe ich einen „eleganten“ Rock gewählt. Natürlich können Sie auch weitere Bedingungen wählen. Mehr werde ich hier nicht sagen.

Allerdings war in der Vergangenheit JavaScript (oder ein JQuery-basiertes Plug-in) erforderlich, um einen solchen Effekt zu erzielen. Zum Beispiel das Inhaltsfilterungsbeispiel von CodyHouse. Aber für einen Studenten, der JavaScript nicht versteht (nicht zu verstehen ist kein Grund), ist es in der Tat schwierig, eine ähnliche Funktion zu implementieren (manchmal habe ich persönliche Erfahrungen und möchte ohne Tränen weinen, wer sagt, dass ich nicht hart gelernt habe). der Anfang).

Glücklicherweise können Puppets jetzt ohne JavaScript implementiert werden. Mit anderen Worten: Es ist nicht schwierig, einen Inhaltsfilter mit einfacheren Funktionen mithilfe von reinem CSS zu implementieren. Das ist es, was ich heute mit Ihnen teilen möchte.

Sehen wir uns zunächst ein Beispiel an

Sehen wir uns zunächst ein einfaches Beispiel an. Wenn die Seite geladen wird, werden Damenbekleidung, Herrenbekleidung und Kinderbekleidung zusammen angezeigt Wenn Sie Folgendes tun, treten beim Betrieb unerwartete Effekte auf:

Wenn Sie auf die Schaltfläche „Damenbekleidung“ klicken, werden „Herrenbekleidung“ und „Kinderbekleidung“ herausgefiltert.

Wenn Sie klicken Wenn Sie auf die Schaltfläche „Herrenbekleidung“ klicken, werden sowohl „Damenbekleidung“ als auch „Kinderbekleidung“ herausgefiltert.

Wenn Sie auf die Schaltfläche „Kinderbekleidung“ klicken, werden sowohl „Damenbekleidung“ als auch „Herrenbekleidung“ ausgefiltert herausgefiltert

Natürlich ist die Funktion in diesem Fall nicht so gut wie die von Taobao. Es ist so NB, aber Haodai implementiert auch eine Funktion ähnlich der Inhaltsfilterung.


Prinzip der Implementierung

Das Prinzip der Implementierung dieser Funktion ist eigentlich nicht allzu kompliziert, aber nicht jeder hat darauf geachtet. Ich kann es in zwei Aspekten zusammenfassen:


Leistungsstarker Selektor

Um diese Funktion zu erreichen, basiert es hauptsächlich auf der universellen Geschwisterauswahl im leistungsstarken CSS-Selektor Selector (E~F) und Pseudoklassenselektor: aktiviert. Wenn ein Optionsfeld ausgewählt ist, wird der Inhalt anderer Kategorien ausgeblendet:

input[type="radio"]{
    &[id="men"]:checked {
        ~ .women,
        ~ .children{
            ....
        }
    }
}
Nach dem Login kopieren

Um die entsprechenden .women- und .children-Elemente über den oben genannten Stil zu steuern, müssen Sie sicherstellen, dass die Elemente stimmen mit überein. Das Eingabeelement ist ein Geschwisterelement. Dies ist auch der zweite wichtige Punkt, der im Folgenden besprochen wird.


Gute, passende Struktur

Die ausschließliche Verwendung von CSS zur Erstellung dieser Funktion erfordert eine strenge Struktur, da sich die Unordnung der Struktur direkt auf die Funktion auswirkt gewünschte Wirkung. Das ist auch sein Manko. Eine davon besteht darin, das Optionsfeld „Radio“ zu verwenden, um die Beschriftung anzupassen. Um ein schönes Erscheinungsbild zu erzielen und nicht anzuzeigen, müssen Sie das ausgewählte „radio“ über das for-Attribut des Labels steuern. Daher muss der ID-Wert der Eingabe mit dem for-Wert des Labels übereinstimmen. Darüber hinaus sind die Namenswerte aller Eingaben gleich, was dem Browser mitteilt, dass sie zu einer Gruppe gehören. Zum Beispiel:

<input type="radio" id="men" name="clothing" />
<label for="men">男装</label>
<input type="radio" id="women" name="clothing"/>
<label for="women">女装</label>
<input type="radio" id="children" name="clothing"/>
<label for="children">童装</label>
<input type="radio" id="reset" name="clothing"/>
<label for="reset">重置</label>
Nach dem Login kopieren

Implementierungsschritte

Nachdem Sie das Implementierungsprinzip verstanden haben, ist es viel einfacher, die Wirkung des Beispiels zu vervollständigen am Anfang des Artikels.


HTML

Die HTML-Struktur ist eigentlich sehr einfach. Sie müssen nur auf die Übereinstimmung von Eingabe und Beschriftung sowie dem zu filternden Inhaltselement und seinem Geschwister achten Element. In diesem Beispiel gibt es beispielsweise drei Hauptkategorien von Inhaltselementen: Herrenbekleidung.Männer, Damenbekleidung.Damen und Kinderbekleidung.Kinder.

<p class="container">
    <!-- 必须保证input和label匹配 -->
    <input type="radio" id="men" name="clothing " />
    <label for="men">男装</label>
    <input type="radio" id="women" name="clothing "/>
    <label for="women">女装</label>
    <input type="radio" id="children" name="clothing "/>
    <label for="children">童装</label>
    <input type="radio" id="reset" name="clothing "/>
    <label for="reset">重置</label>
    <!-- 要被过滤的内容元素需要与input元素是兄弟元素 -->
    <p class="tile men">
        <img src="/static/imghw/default1.png"  data-src="" alt="  class="lazy"   alt="">
    </p>
    <p class="tile women">
        <img src="/static/imghw/default1.png"  data-src="" alt="  class="lazy"   alt="">
    </p>
    <p class="tile children">
        <img src="/static/imghw/default1.png"  data-src="" alt="  class="lazy"   alt="">
    </p>
    <!-- 此处省略N个.men、.women和.children元素 -->
</p>
Nach dem Login kopieren

SCSS

Es ist viel einfacher, wenn Sie das Prinzip verstehen:

body{
  margin:0;
  text-align:center;
  font-family: Verdana;
  background:#f5f5f5;
}
h1 {
  text-align:center;
}
.container {
  width:90%;
  margin:0 auto;
}
input[type="radio"] {
  display:none;
}
label {
  width:23%;
  float:left;
  text-align:center;
  background:#ffffff;
  box-shadow: 0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
  color:#222222;
  padding:0.5%;
  margin:0.5%;
  margin-bottom:30px;
  cursor:pointer;
}
input[type="radio"]{
  &[id="men"]:checked {
    * label {
      background:#6666ff;
    }
    ~ .women,
    ~ .children {
      width:0;
      height:0;
      padding:0;
      margin:0;
      opacity:0;
    }
  }
  &[id="women"]:checked {
    * label {
      background:#ff4466;
    }
    ~ .men,
    ~ .children {
      width:0;
      height:0;
      padding:0;
      margin:0;
      opacity:0;
    }
  }
  &[id="children"]:checked {
    * label {
      background:#66dd99;
    }
    ~ .men, 
    ~ .women {
      width:0;
      height:0;
      padding:0;
      margin:0;
      opacity:0;
    }
  }
}
.tile {
  width:23%;
  float:left;
  transition:all 1s;
  margin:0.5%;
  padding:0.5%;
  background:#6666ff;
  img {
      width: 100%;
    }
}
Nach dem Login kopieren

Analysieren Sie diesen Stilcode kurz.

Um die Seite besser aussehen zu lassen, blenden Sie zunächst die aus:

input[type="radio"] {
  display:none;
}
Nach dem Login kopieren

Wir verwenden das for-Attribut des Labels, um zu steuern, ob die Radio ausgewählt ist. Verschönern Sie den Etikettenstil:

label {
    width:23%;
    float:left;
    text-align:center;
    background:#ffffff;
    box-shadow: 0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
    color:#222222;
    padding:0.5%;
    margin:0.5%;
    margin-bottom:30px;
    cursor:pointer;
}
Nach dem Login kopieren

Der nächste Stilcode ist auch der kritischste Teil. Wenn die Eingabe ausgewählt wird, ist der Etikettenstil:

input[type="radio"]{
  &[id="men"]:checked {
      label {
      background:#6666ff;
    }
  }
  ...
}
Nach dem Login kopieren

Der obige Code stellt dar, wenn er aktiviert ist, ändert die angrenzende Beschriftung die Hintergrundfarbe.

Gemäß der vorherigen Grundsatzeinführung können wir wissen, dass bei der Auswahl von „Männerbekleidung“ auch „Damenbekleidung“ und „Kinderbekleidung“ ausgeblendet werden müssen, hier werden sie also durch falsche Bilder ausgeblendet , input[type= "radio"][id="men"] ist ausgewählt und seine ähnlichen Geschwisterelemente .women und .children sind ausgeblendet:

input[type="radio"]{
  &[id="men"]:checked {
    ...
    ~ .women,
    ~ .children {
      width:0;
      height:0;
      padding:0;
      margin:0;
      opacity:0;
    }
  }
}
Nach dem Login kopieren

其他两个选项也是类似的,就不在做过多的阐述。

美化的样式,这里就不说了,大家都懂的。

通过这个过程下来,你就能看到前面DEMO展示的效果了。
总结

本文主要介绍了如何依赖于CSS的属性选择器、通用相邻兄弟选择器和伪类选择器来实现一个简单的Verwenden Sie reines CSS, um die Filtermenüfunktion zu implementieren的功能。在整个实例当中,要把握的是严谨的HTML结构,因为相邻兄弟选择器对于结构的依赖程度非常的强。也就是说结构修改之后,你的选择器和样式都要做一定的修改。
相关推荐:

最简洁的CSS学习笔记

全面总结css中属性值继承知识

css和js实现弹出登录居中界面教程

Das obige ist der detaillierte Inhalt vonVerwenden Sie reines CSS, um die Filtermenüfunktion zu implementieren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Was bedeutet Platzhalter in Vue? Was bedeutet Platzhalter in Vue? May 07, 2024 am 09:57 AM

In Vue.js gibt das Platzhalterattribut den Platzhaltertext des Eingabeelements an, der angezeigt wird, wenn der Benutzer keinen Inhalt eingegeben hat, Eingabetipps oder Beispiele bereitstellt und die Barrierefreiheit des Formulars verbessert. Seine Verwendung besteht darin, das Platzhalterattribut für das Eingabeelement festzulegen und das Erscheinungsbild mithilfe von CSS anzupassen. Zu den Best Practices gehört es, relevant für die Eingabe zu sein, kurz und klar zu sein, Standardtexte zu vermeiden und die Barrierefreiheit zu berücksichtigen.

Was bedeutet span in js Was bedeutet span in js May 06, 2024 am 11:42 AM

Das Span-Tag kann Stile, Attribute oder Verhaltensweisen zum Text hinzufügen. Es wird verwendet, um Stile wie Farbe und Schriftgröße hinzuzufügen. Legen Sie Attribute wie ID, Klasse usw. fest. Zugehörige Verhaltensweisen wie Klicks, Hovers usw. Markieren Sie Text zur weiteren Bearbeitung oder zum Zitieren.

Was bedeutet rem in js Was bedeutet rem in js May 06, 2024 am 11:30 AM

REM in CSS ist eine relative Einheit relativ zur Schriftgröße des Stammelements (HTML). Es weist die folgenden Merkmale auf: relativ zur Schriftgröße des Stammelements, nicht vom übergeordneten Element beeinflusst. Wenn sich die Schriftgröße des Stammelements ändert, werden Elemente, die REM verwenden, entsprechend angepasst. Kann mit jeder CSS-Eigenschaft verwendet werden. Zu den Vorteilen der Verwendung von REM gehören: Reaktionsfähigkeit: Halten Sie den Text auf verschiedenen Geräten und Bildschirmgrößen lesbar. Konsistenz: Stellen Sie sicher, dass die Schriftgrößen auf Ihrer gesamten Website einheitlich sind. Skalierbarkeit: Ändern Sie die globale Schriftgröße ganz einfach, indem Sie die Schriftgröße des Stammelements anpassen.

So führen Sie Bilder in Vue ein So führen Sie Bilder in Vue ein May 02, 2024 pm 10:48 PM

Es gibt fünf Möglichkeiten, Bilder in Vue einzuführen: über URL, Require-Funktion, statische Datei, V-Bind-Direktive und CSS-Hintergrundbild. Dynamische Bilder können in den berechneten Eigenschaften oder Listenern von Vue verarbeitet werden, und gebündelte Tools können zum Optimieren des Bildladens verwendet werden. Stellen Sie sicher, dass der Pfad korrekt ist, da sonst ein Ladefehler auftritt.

In welcher Sprache ist das Browser-Plugin geschrieben? In welcher Sprache ist das Browser-Plugin geschrieben? May 08, 2024 pm 09:36 PM

Browser-Plugins werden normalerweise in den folgenden Sprachen geschrieben: Front-End-Sprachen: JavaScript, HTML, CSS Back-End-Sprachen: C++, Rust, WebAssembly Andere Sprachen: Python, Java

Was ist die GateToken(GT)-Währung? Einführung in die GT-Münzfunktionen und die Token-Ökonomie Was ist die GateToken(GT)-Währung? Einführung in die GT-Münzfunktionen und die Token-Ökonomie Jul 15, 2024 pm 04:36 PM

Was ist die GateToken(GT)-Währung? GT (GateToken) ist der native Vermögenswert in der GateChain-Kette und die offizielle Plattformwährung von Gate.io. Der Wert von GT-Münzen hängt eng mit der Entwicklung der Ökologie von Gate.io und GateChain zusammen. Was ist GateChain? GateChain wurde 2018 geboren und ist eine neue Generation leistungsstarker öffentlicher Ketten, die von Gate.io eingeführt wurde. GateChain konzentriert sich auf den Schutz der Sicherheit der On-Chain-Assets der Benutzer und die Bereitstellung bequemer dezentraler Transaktionsdienste. Das Ziel von GateChain besteht darin, ein sicheres und effizientes dezentrales Ökosystem für die Speicherung, Verteilung und Transaktion digitaler Assets auf Unternehmensebene aufzubauen. Gatechain hat Original

Was ist ein Knoten in js? Was ist ein Knoten in js? May 07, 2024 pm 09:06 PM

Knoten sind Entitäten im JavaScript-DOM, die HTML-Elemente darstellen. Sie stellen ein bestimmtes Element auf der Seite dar und können verwendet werden, um auf dieses Element zuzugreifen und es zu bearbeiten. Zu den gängigen Knotentypen gehören Elementknoten, Textknoten, Kommentarknoten und Dokumentknoten. Über DOM-Methoden wie getElementById() können Sie auf Knoten zugreifen und diese bearbeiten, einschließlich der Änderung von Eigenschaften, dem Hinzufügen/Entfernen untergeordneter Knoten, dem Einfügen/Ersetzen von Knoten und dem Klonen von Knoten. Das Durchqueren von Knoten hilft bei der Navigation innerhalb der DOM-Struktur. Knoten sind nützlich für die dynamische Erstellung von Seiteninhalten, die Ereignisbehandlung, Animation und Datenbindung.

So legen Sie unbekannte Attribute in vscode fest vscode-Methode zum Festlegen unbekannter Attribute So legen Sie unbekannte Attribute in vscode fest vscode-Methode zum Festlegen unbekannter Attribute May 09, 2024 pm 02:43 PM

1. Öffnen Sie zunächst das Einstellungssymbol in der unteren linken Ecke und klicken Sie auf die Option „Einstellungen“. 2. Suchen Sie dann die CSS-Spalte im Sprungfenster. 3. Ändern Sie abschließend die Dropdown-Option im Menü „Unbekannte Eigenschaften“ in die Schaltfläche „Fehler“. .

See all articles