Heim > Web-Frontend > js-Tutorial > Hauptteil

Detaillierte grafische Erläuterung des Clip-Pfads zur Implementierung der Animation mit fließendem Rand der Schaltfläche

藏色散人
Freigeben: 2023-04-11 15:13:15
nach vorne
1649 Leute haben es durchsucht

Dieser Artikel vermittelt Ihnen relevantes Wissen über Front-End-Schaltflächen. Es geht hauptsächlich darum, wie Sie Clip-Path zum Implementieren von Schaltflächen-Flow-Randanimationen verwenden. Ich hoffe, dass es für Sie hilfreich ist.

1. Implementieren Sie den Effekt.

Detaillierte grafische Erläuterung des Clip-Pfads zur Implementierung der Animation mit fließendem Rand der Schaltfläche

2. Implementieren Sie die Schritte. Div-Tag hinzufügen s zum div. Um die Unterscheidung zu erleichtern, legen Sie das Vorher und Nachher fest. Die Rahmenfarben von Pseudoelementen sind unterschiedlich.

<div>苏苏_icon</div>
Nach dem Login kopieren
Einfügungsattribut: Wird zum Festlegen von links/rechts/unten/oben verwendet Erstellen Sie den anzeigbaren Bereich des Elements. Teile innerhalb des Bereichs werden angezeigt und Teile außerhalb des Bereichs ausgeblendet. inset() definiert ein eingefügtes Rechteck.
Syntax:

Detaillierte grafische Erläuterung des Clip-Pfads zur Implementierung der Animation mit fließendem Rand der Schaltfläche

div {
  position: relative;
  width: 220px;
  height: 64px;
  line-height: 64px;
  text-align: center;
  color: #fff;
  font-size: 20px;
  background: #55557f;
  cursor: pointer;
  border-radius: 10px;
}
Nach dem Login kopieren

    Erläuterung:

Wenn alle vier Parameter bereitgestellt werden: Detaillierte grafische Erläuterung des Clip-Pfads zur Implementierung der Animation mit fließendem Rand der Schaltfläche

Sie stellen den oberen, rechten, unteren und linken Versatz nach innen vom Referenzfeld dar. Der Versatz definiert, wo die Die Kanten des Rechtecks ​​werden eingefügt. Diese Parameter folgen der Syntax der Margin-Kurzform, sodass Sie einen, zwei oder vier Werte für alle vier Abbildungen festlegen können.
Optionaler Parameter „border-radiu“:

Detaillierte grafische Erläuterung des Clip-Pfads zur Implementierung der Animation mit fließendem Rand der SchaltflächeVerwenden Sie die Kurzschriftsyntax „border-radius“, um abgerundete Ecken für das eingefügte Rechteck zu definieren.

Wir versuchen, den Einschub für das Pseudoelement festzulegen

div::after,
div::before {
   content: "";
   position: absolute;
   width: 240px;
   height: 84px;
   border: 2px solid #55557f;
   border-radius: 10px;
 }
div::before{
 border: 2px solid orange;
}
Nach dem Login kopieren
  • div::after,
    div::before{
     + left: calc(110px - 120px);
     + top: calc(32px - 42px);
    }
    Nach dem Login kopieren

div::after,
div::before{
 - left: calc(110px - 120px);
 - top: calc(32px - 42px);
 - inset: -10px;
}
Nach dem Login kopieren
Animation hinzufügen

  • clip-path: inset(20px 50px 10px 0 round 50px);
    Nach dem Login kopieren
    div::after,
    div::before{
      + clip-path: inset(0 0 98% 0);
    }
    Nach dem Login kopieren
    Animationsverzögerung zum Post-Pseudoelement hinzufügen, um einen Parallaxeneffekt zu erzeugen

animation-delay

:

CSS-Eigenschaften angeben die ab anzuwendende Animation. Die Wartezeit, bevor das Element mit der Animation beginnt. Die Animation kann später, sofort von Anfang an oder direkt in der Mitte der Animation beginnen.

Ein positiver Wert gibt an, dass die Animation nach Ablauf der angegebenen Zeit starten soll. Der Standardwert von 0s bedeutet, dass die Animation sofort nach der Anwendung starten soll.

Detaillierte grafische Erläuterung des Clip-Pfads zur Implementierung der Animation mit fließendem Rand der Schaltfläche Negative Werte bewirken, dass die Animation sofort startet, aber mitten in der Schleife beginnt. Wenn Sie beispielsweise eine Animationsverzögerungszeit von -1 s angeben, startet die Animation sofort, jedoch 1 Sekunde nach Beginn der Animationssequenz. Wenn Sie einen negativen Wert für die Animationsverzögerung angeben, der Startwert jedoch implizit ist, wird der Startwert ab dem Zeitpunkt übernommen, an dem die Animation auf das Element angewendet wird.

    div::after,
    div::before{
      + clip-path: inset(0 98% 0 0);
    }
    Nach dem Login kopieren
  • Entfernen Sie die Rahmenfarbwerteinstellung des vorderen Pseudoelements

Detaillierte grafische Erläuterung des Clip-Pfads zur Implementierung der Animation mit fließendem Rand der Schaltfläche

div::after,
div::before{
  + clip-path: inset( 98% 0  0 0);
}
Nach dem Login kopieren
Detaillierte grafische Erläuterung des Clip-Pfads zur Implementierung der Animation mit fließendem Rand der Schaltfläche

div und fügen Sie ein Hover-Ereignis hinzu, und fertig ~

Detaillierte grafische Erläuterung des Clip-Pfads zur Implementierung der Animation mit fließendem Rand der Schaltfläche

Detaillierte grafische Erläuterung des Clip-Pfads zur Implementierung der Animation mit fließendem Rand der Schaltfläche

div:hover {
  filter: brightness(1.5);
}
Nach dem Login kopieren
div{	/* 添加过渡效果 */
	transition: all 0.5s;
}
Nach dem Login kopieren

3.实现代码



  
    
    clip-path实现按钮流动边框
  
  
  
  
    <div>苏苏_icon</div>
  
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonDetaillierte grafische Erläuterung des Clip-Pfads zur Implementierung der Animation mit fließendem Rand der Schaltfläche. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:juejin.im
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