Kürzlich habe ich auf der Website von Corey Ginnivan ein faszinierendes Designelement entdeckt: einen Kartenstapel, der sich während des Scrollens dynamisch neu positioniert.
Anfangs nahm ich an, dass dies ein umfangreiches JavaScript erfordern würde. Ich erkannte jedoch schnell, dass die elegante Lösung in position: sticky
und ein Hauch von Sass. Anstatt Coreys Ansatz zu replizieren, habe ich beschlossen, meine eigene Version zu erstellen.
Lassen Sie uns zunächst grundlegende Kartenstile definieren:
Körper { Hintergrund: Linear-Gradient ( #e8e8e8, #e0e0e0); } .Wrapper { Rand: 0 Auto; Max-Breite: 700px; } .Card { Hintergrundfarbe: #fff; Grenze: 1PX Solid #CCC; Border-Radius: 10px; Box-Shadow: 5px 5px 5px RGBA (0, 0, 0, 0,1); Farbe: #333; Polsterung: 40px; }
Um den klebrigen Effekt zu erzielen, wenden wir position: sticky
und setzen einen oberen Offset:
.Card { Position: klebrig; Top: 10px; / * Andere Kartenstile *// }
Dies schafft das anfängliche klebrige Verhalten. Um den gestapelten Effekt zu simulieren, nutzen wir Sass's @for
Loop:
@Für $ i von 1 bis 8 { .KARD: N-CHild (#{$ i} n) { Oben: $ I * 20px; } }
Diese Schleife passt die top
Eigenschaft für jede Karte an und erstellt die Stapel -Illusion.
Dieser Ansatz führt zu einem visuell ansprechenden Ergebnis. Weitere Verfeinerungen könnten das Anpassen der Box-Shadow- und Kartenfarben für eine verbesserte Ästhetik sein.
Ich wollte jedoch alternative Layouts erkunden. Inspiriert von einem anderen Design auf dieser Website, experimentierte ich mit einer horizontalen Anordnung mit Flexbox:
.Wrapper { Anzeige: Flex; Überlauf-X: Scrollen; } .Card { Höhe: 60 VH; Min-Width: 50VW; Position: klebrig; TOP: 5VH; links: 10VW; }
Um ein dynamisches, randomisiertes Element hinzuzufügen, habe ich die random()
-Funktion von Sass in die Schleife integriert:
@Für $ i von 1 bis 8 { .KARD: N-CHild (#{$ i} n) { Links: $ I * 20px Random (200) * 1px; Oben: $ I * 1PX Random (130) * 1px; Transformation: Drehen (zufällig (3) - 2 * 1DEG); } }
Diese Modifikation führt zu zufälligen Offsets und Drehungen für jede Karte, was zu einer spielerischeren und dynamischeren Präsentation führt.
Die Kraft und Flexibilität der position: sticky
werden in diesen Beispielen deutlich demonstriert.
Das obige ist der detaillierte Inhalt vonGestapelte Karten mit klebriger Positionierung und einem Schuss Sass. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Die Auswahl von Flexbox oder Grid hängt von den Layoutanforderungen ab: 1) Flexbox ist für eindimensionale Layouts wie die Navigationsleiste geeignet. 2) Das Gitter eignet sich für zweidimensionale Layouts wie Zeitschriftenlayouts. Die beiden können im Projekt verwendet werden, um den Layout -Effekt zu verbessern.

Der beste Weg, um CSS -Dateien einzubeziehen, besteht darin, Tags zu verwenden, um externe CSS -Dateien in den HTML -Teil einzuführen. 1. Verwenden Sie Tags, um externe CSS -Dateien einzuführen, wie z. 2. Für kleine Anpassungen können Inline -CSS verwendet werden, sollten jedoch mit Vorsicht verwendet werden. 3. Große Projekte können CSS -Präprozessoren wie SASS oder weniger verwenden, um andere CSS -Dateien über @import zu importieren. 4. Für die Leistung sollten CSS -Dateien zusammengeführt und CDN verwendet und mit Tools wie CSSNano komprimiert werden.

Ja, youShouldlearnbothflexBoxandgrid.1) FlexBoxiSidealfore-dimensional, flexibelayoutslikenAvigationMenus.2) GridexcelStwo-dimensional, komplexDesignsuchasmagazinelayouts.3) Kombininierungs-Botenhances-Flexible-und-und -Anteilungskraft, und -forsfossivität,

Wie sieht es aus, Ihren eigenen Code neu zu gestalten? John Rhea nimmt eine alte CSS -Animation auseinander, die er geschrieben hat, und geht durch den Denkprozess der Optimierung.

CsSanimationsarenotinherenthardbutRequirePractICEANDUnDing-fordertofcsPropertiesandTimingfunktionen.1) StartwithsimpleanimationslikescalingabuttononoversKeyFrames.2) useaSingFunctionslikecubic-BezierForteffects, SuchasabouNects, SuchasabouNects,, zu

@KeyFramesispopulardUeToitSverSatility und PowerIncreatingsmoothcsSanimations.KectrickSinclude: 1) DefiningsmoothTransitionSbetTates, 2) AnimatingMultipleProperTiesimultan, 3) mit VendorprefixesforBrowserCompatible, 4) Kombinieren, 4) Kombinieren, 4) Kombinieren, 4) Kombinieren, 4) Kombinieren

CSSCOUSTERSSARUSTOMANAGEAUTOMATICNUMBERINGINWEBDEsigns.1) Sie konzipieren SieForsofcontents, ListItems und CustomNumbering.2) AdvanceduSesincnednumberingSystem.3) CHEFORDIGESINCLUDSERCOMPATIBILIBLEISE.4) CreativeuSinvolvecustInance

Die Verwendung von Scroll -Schatten, insbesondere für mobile Geräte, ist ein subtiles Stück UX, das Chris zuvor abgedeckt hat. Geoff deckte einen neueren Ansatz ab, der die Immobilie der Animationszeit verwendet. Hier ist ein anderer Weg.


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

SublimeText3 Linux neue Version
SublimeText3 Linux neueste Version

ZendStudio 13.5.1 Mac
Leistungsstarke integrierte PHP-Entwicklungsumgebung

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.

WebStorm-Mac-Version
Nützliche JavaScript-Entwicklungstools

PHPStorm Mac-Version
Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool
