Heim > Web-Frontend > CSS-Tutorial > So verwenden Sie reines CSS, um den Hover-Effekt von Schiebeelementen auf beiden Seiten der Schaltfläche zu erzielen (Quellcode im Anhang)

So verwenden Sie reines CSS, um den Hover-Effekt von Schiebeelementen auf beiden Seiten der Schaltfläche zu erzielen (Quellcode im Anhang)

不言
Freigeben: 2018-10-08 16:41:41
nach vorne
2296 Leute haben es durchsucht

Der Inhalt dieses Artikels befasst sich mit der Verwendung von reinem CSS, um den Hover-Effekt von gleitenden Elementen auf beiden Seiten der Schaltfläche zu erzielen (Quellcode im Anhang), auf den sich Freunde in Not beziehen können Ich hoffe, es hilft dir.

Effektvorschau

So verwenden Sie reines CSS, um den Hover-Effekt von Schiebeelementen auf beiden Seiten der Schaltfläche zu erzielen (Quellcode im Anhang)

Quellcode-Download

https://github.com/comehope/front- end-daily-challenges

Codeinterpretation

Dom definieren, der Container ist eine ungeordnete Liste und die Listenelemente stellen Schaltflächen dar:

Nach dem Login kopieren
Nach dem Login kopieren
        
  • home

Zentrierte Anzeige:

body {
  margin: 0;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(deepskyblue, navy);
}
Nach dem Login kopieren

Entfernen Sie das Symbol vor dem Listenelement:

ul {
  padding: 0;
  list-style-type: none;
}
Nach dem Login kopieren

Legen Sie den Textstil der Schaltfläche fest:

ul li {
  color: #ddd;
  font-size: 25px;
  font-family: sans-serif;
  text-transform: uppercase;
}
Nach dem Login kopieren

Verwenden Sie ein Pseudoelement, um links neben der Schaltfläche ein Feld hinzuzufügen:

ul li {
  position: relative;
}

ul li::before {
  content: '';
  position: absolute;
  width: 100%;
  height: 100%;
  background: tomato;
  left: -100%;
}
Nach dem Login kopieren

Pseudoelement verwenden Fügen Sie rechts neben der Schaltfläche eine Unterstreichung hinzu:

ul li::after {
  content: '';
  position: absolute;
  width: 100%;
  height: 0.2em;
  background: tomato;
  bottom: 0;
  left: 100%;
}
Nach dem Login kopieren

Richten Sie als Nächstes den Mouseover-Effekt ein.
Wenn Sie mit der Maus darüber fahren, bewegt sich das Quadrat auf der linken Seite an die Position des Texts:

ul li::before {
  transition: 0.4s ease-out;
}

ul li:hover::before {
  left: 100%;
}
Nach dem Login kopieren

Die Unterstreichung auf der rechten Seite bewegt sich an die Position des Texts und ihre Animationszeit wird bis zum verzögert Die Animation des Quadrats endet kurz vor dem Start:

ul li::after {
  transition: 0.3s 0.3s ease-out;
}

ul li:hover::after {
  left: 0%;
}
Nach dem Login kopieren

Erhöhen Sie gleichzeitig die Helligkeit des Textes:

ul li {
  transition: 0.3s;
  cursor: pointer;
}

ul li:hover {
  color: #fff;
}
Nach dem Login kopieren

Verstecken Sie den Teil außerhalb der Schaltfläche, sodass die Quadrate und Unterstreichungen sind standardmäßig unsichtbar. Sie ändern sich nur von beiden Seiten, wenn die Maus darüber schwebt:

ul li {
  overflow: hidden;
}
Nach dem Login kopieren

Fügen Sie zum Schluss noch ein paar Schaltflächen zum Dom hinzu:

Nach dem Login kopieren
Nach dem Login kopieren
        
  • home
  •     
  • products
  •     
  • services
  •     
  • contact

Legen Sie mehrere Schaltflächen an :

ul {
  display: flex;
  flex-direction: column;
  align-items: center;
}

ul li {
  margin: 0.5em;
}
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonSo verwenden Sie reines CSS, um den Hover-Effekt von Schiebeelementen auf beiden Seiten der Schaltfläche zu erzielen (Quellcode im Anhang). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:segmentfault.com
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage