suchen
HeimWeb-FrontendCSS-TutorialMenü enthüllen nach Seite Drehen Animation

Menü enthüllen nach Seite Drehen Animation

Die Website -Menü -Designmethoden sind vielfältig. Einige Menüs sind immer sichtbar und alle Optionen werden direkt angezeigt. Andere sind versteckt und müssen geklickt werden, um zu erweitern. Die Art und Weise, wie die versteckten Menüs erweitert werden, ist anders: Einige rutschen und abdecken Inhalte, einige schieben den Inhalt weg und einige verwenden Vollbildanzeige.

Jede Methode hat ihre Vor- und Nachteile, und die beste Wahl hängt vom spezifischen Anwendungsszenario ab. Ich persönlich bevorzuge das Ausrutschenmenü, und sicherlich gelten nicht alle Situationen. Wenn jedoch ein platzsparendes und leicht zugängliches Menü benötigt wird, ist das Ausrutschenmenü schwer zu übertreffen.

Ausrutschenmenüs in Konflikt jedoch häufig mit Seiteninhalten. Es wird zumindest den Inhalt blockieren und im schlimmsten Fall den Inhalt vollständig aus der Benutzeroberfläche entfernt.

Ich habe einen anderen Ansatz ausprobiert, der die Haltbarkeit und Verwendbarkeit eines festen Standortmenüs sowie das platzsparende versteckte Ausrutschenmenü kombiniert, ohne den Benutzer aus dem aktuellen Inhalt zu entfernen.

Hier ist meine Implementierungsmethode.

Schalterschalter

Wir bauen ein Menü mit zwei Zuständen (Ein und Schließen) und wechseln zwischen den beiden. Hier kommt der Checkbox -Trick ins Spiel. Es ist perfekt, da das Kontrollkästchen zwei gemeinsame interaktive Zustände enthält - überprüft und deaktiviert (und unsicheren Zuständen), mit denen diese Zustände ausgelöst werden können.

Das Kontrollkästchen ist im Menüsymbol versteckt und mit CSS positioniert, sodass es nicht ersichtlich ist, wenn der Benutzer mit ihm interagiert. Durch Auswahl des Kontrollkästchens (oder, ähm , Menüsymbol) wird das Menü angezeigt. Deaktivieren Sie es. Es ist so einfach. Wir brauchen nicht einmal JavaScript, um den Job zu erledigen!

Natürlich sind Kontrollkästchen -Tricks nicht der einzige Weg, und wenn Sie den Unterricht mit JavaScript wechseln möchten, um Menüs zu öffnen und zu schließen, ist das völlig in Ordnung.

Wichtig ist, dass das Kontrollkästchen dem Hauptinhalt im Quellcode voraus sein sollte, da wir schließlich den :checked Selektor schreiben werden, für den der Geschwisterauswahl ausgewählt wird. Wenn dies Layoutprobleme verursacht, verwenden Sie Grid oder Flexbox für Layouts, da sie nichts mit Quellcode -Reihenfolge zu tun haben, z. B. wie ich seine Vorteile für die CSS -Zählung nutzen kann.

Verwenden Sie appearance -CSS-Eigenschaft, um den Standardstil des Kontrollkästchens (vom Browser hinzugefügt) zu entfernen, und fügen Sie dann ein Pseudo-Element mit einem Menüsymbol hinzu, damit der Benutzer die Kontrollkästchen-Blöcke nicht sehen kann.

Erstens die Basis -Tags:

<input type="checkbox" id="menu-toggle">
<div id="page">
  
</div>
<div id="menu">
  
</div>

Und grundlegende CSS für Kontrollkästchen Tricks und Menüsymbole:

 /* Verstecken Sie das Kontrollkästchen und setzen Sie den Stil zurück*/
input [type = "checkbox"] {
  Aussehen: Initial; /* Box löschen*/
  Grenze: 0; Rand: 0; Umriss: Keine; /* Entfernen Sie Standardmargen, Grenzen und Umrisse*/
  Breite: 30px; Höhe: 30px; /* Menüsymbolgröße einstellen*//*
  Z-Index: 1; /* Stellen Sie sicher, dass es oben ist*/
}

/* Menüsymbol*//
input :: nach {
  Inhalt: "\ 2255";
  Anzeige: Block;
  Schriftart: 25pt/30px "Georgia";
  textindent: 10px;
  Breite: 100%; Höhe: 100%;
}

/* Page Inhalt Container*///
#Seite {
  Hintergrund: URL ("Earbuds.jpg") #ebebeb Center/Cover;
  Breite: 100%; Höhe: 100%;
}

Ich habe auch den Stil von #page -Inhalten hinzugefügt, der ein Hintergrundbild in voller Größe ist.

Übergangseffekt

Es passieren zwei Dinge, wenn Sie auf eine Menüsteuerung klicken. Zunächst wird das Menüsymbol in die "×" -Marke geändert, die angibt, dass Sie darauf klicken können, um das Menü zu schließen. Wenn sich die Eingabe in dem :checked Status befindet, wählen wir also das in das Kontrollkästchen ::after Pseudo-Element aus:

 Eingabe: Checked :: After {
  Inhalt: "\ 00D7"; /* Wechseln Sie zu "×" Tag*/
  Farbe: #ebebeb;
}

Zweitens wird der Hauptinhalt (unser "Kopfhörer" -Abbild) konvertiert, um das folgende Menü anzuzeigen. Es bewegt sich nach rechts, dreht sich und schrumpft und die linke Ecke wird zum Winkel. Dies soll den Inhalt so aussehen, als würde er wie eine offene Tür zurückgedrückt werden.

 Eingabe: geprüft ~ #page {
  Clip-Pfad: Polygon (0 8%, 100%0, 100%100%, 0 92%);
  Transformation: Translatex (40%) Drehung (10DEG) Skala (0,8);
  Transform-Origin: Right Center;
  Übergang: alle .3s linear;
}

Ich verwende clip-path um den Bildwinkel zu ändern.

Da wir Übergänge zur Transformation anwenden, erfordert #page einen anfänglichen clip-path -Wert, damit der Übergang etwas vornimmt. Wir werden auch einen Übergang auf #page hinzufügen, da er es ermöglicht, reibungslos zu schließen, wenn er sich öffnet.

 #Seite {
  Hintergrund: URL ("Earbuds.jpeg") #ebebeb Center/Cover;
  Clip-Pfad: Polygon (0 0, 100% 0, 100% 100%, 0 100%);
  Übergang: alle .3s linear;
  Breite: 100%; Höhe: 100%;
}

Wir haben im Grunde das Kerndesign und Code abgeschlossen. Wenn das Kontrollkästchen nicht überprüft ist (indem Sie auf die Marke "×" klicken), wird die Konvertierung im Headset -Bild automatisch rückgängig gemacht und in die Mitte -Position zurückgeführt.

Ein kleines JavaScript

Auch wenn wir bereits das haben, was wir wollen, gibt es noch eine Sache, um die Benutzererfahrung zu verbessern: Schließen Sie das Menü beim Klicken (oder klicken) #page -Element. Auf diese Weise kann der Benutzer den Inhalt zurückgeben, ohne das "×" -Tag zu suchen oder sogar zu verwenden.

Da dies nur eine weitere Möglichkeit ist, das Menü zu verbergen, können wir JavaScript verwenden. Was ist, wenn JavaScript aus irgendeinem Grund deaktiviert ist? Es spielt keine Rolle. Es ist nur eine Verbesserung, die das Menü nicht daran hindert, ohne es zu arbeiten.

 Document.querySelector ("#Seite"). AddEventListener ('Click', (E, CheckBox = Document.querySelector ('Eingabe')) => {
  if (CheckBox.Conted) {CheckBox.Conted = false; E.Stoppropagation (); }
});

Der Zweck dieser drei Codezeilen besteht darin, #page einen Klick -Ereignis -Handler hinzuzufügen. Wenn sich das Kontrollkästchen im :checked Status befindet, deaktivieren Sie das Kontrollkästchen, um das Menü zu schließen.

Wir haben uns die Demos angesehen, die für vertikale/vertikale Designs hergestellt wurden, aber es funktioniert auf großen Bildschirmgrößen genauso gut, je nachdem, was wir verwenden.

Dies ist nur ein Weg oder versuchen Sie es mit einem typischen Ausrutschenmenü. Animation eröffnet viele Möglichkeiten, und Sie haben möglicherweise auch Dutzende anderer Ideen. Tatsächlich würde ich sie gerne hören (oder besser noch sehen), also bitte teilen!

Das obige ist der detaillierte Inhalt vonMenü enthüllen nach Seite Drehen Animation. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
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
Draggin ' und Dropfen ' in ReactDraggin ' und Dropfen ' in ReactApr 17, 2025 am 11:52 AM

Das React -Ökosystem bietet uns viele Bibliotheken, die alle auf die Interaktion von Drag & Drop konzentrieren. Wir haben React-Dnd, React-beautiful-dnd,

Schnelle SoftwareSchnelle SoftwareApr 17, 2025 am 11:49 AM

In letzter Zeit gab es einige wunderbar miteinander verbundene Dinge über schnelle Software.

Verschachtelte Gradienten mit HintergrundclipVerschachtelte Gradienten mit HintergrundclipApr 17, 2025 am 11:47 AM

Ich kann nicht sagen, dass ich das all das oft im Hintergrund-Clip verwende. I ' D Wette It ' wird in der täglichen CSS-Arbeit kaum jemals verwendet. Aber ich wurde in einem Posten von Stefan Judis daran erinnert,

Verwenden von RequestAnimationFrame mit React -HooksVerwenden von RequestAnimationFrame mit React -HooksApr 17, 2025 am 11:46 AM

Die Animation mit RequestAnimationFrame sollte einfach sein, aber wenn Sie die Dokumentation von React nicht gründlich gelesen haben, werden Sie wahrscheinlich auf ein paar Dinge stoßen

Müssen Sie nach oben auf der Seite scrollen?Müssen Sie nach oben auf der Seite scrollen?Apr 17, 2025 am 11:45 AM

Vielleicht ist der einfachste Weg, dies dem Benutzer anzubieten, ein Link, der auf eine ID auf das Element abzielt. Also wie ...

Die beste API (GraphQL) ist eine, die Sie schreiben, die Sie schreibenDie beste API (GraphQL) ist eine, die Sie schreiben, die Sie schreibenApr 17, 2025 am 11:36 AM

Hören Sie, ich bin kein GraphQL -Experte, aber ich arbeite gerne damit. Die Art und Weise, wie es mir Daten als Front-End-Entwickler vorstellt, ist ziemlich cool. Es ist wie ein Menü von

Wöchentliche Plattform News: Textabstand Lesezeichen, Top-Level-Erwartung, neuer Verstärker-LadeindikatorWöchentliche Plattform News: Textabstand Lesezeichen, Top-Level-Erwartung, neuer Verstärker-LadeindikatorApr 17, 2025 am 11:26 AM

In der Roundup in dieser Woche, einem praktischen Lesezeichen für die Inspektion von Typografie, unter Verwendung dessen, wie sich JavaScript -Module gegenseitig importieren, sowie Facebook ' s.

Verschiedene Methoden zur Erweiterung einer Schachtel und gleichzeitig den GrenzradiusVerschiedene Methoden zur Erweiterung einer Schachtel und gleichzeitig den GrenzradiusApr 17, 2025 am 11:19 AM

I ' Ich habe kürzlich eine interessante Änderung auf Codepen bemerkt: Als es ein Rechteck mit abgerundeten Ecken auf der Homepage schwebt, expandieren Sie sich im Rücken.

See all articles

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)
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SecLists

SecLists

SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Leistungsstarke integrierte PHP-Entwicklungsumgebung