Heim > Web-Frontend > CSS-Tutorial > Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!

Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!

青灯夜游
Freigeben: 2021-09-13 18:28:46
nach vorne
2687 Leute haben es durchsucht

Verwenden Sie den CSS-Filter geschickt, um Ihre Website cooler zu gestalten. Dieser Artikel gibt Ihnen einige Tipps zur Verwendung von CSS-Filtern. Ich hoffe, er wird Ihnen hilfreich sein!

Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!

Beginnen wir mit dem Inhalt dieses Artikels!

Wenn wir Bilder verarbeiten, verwenden wir häufig Filter, die einem Bild verschiedene visuelle Effekte verleihen können.

Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!

In CSS gibt es auch ein Filterattribut, mit dem wir mithilfe von CSS-Code verschiedene Filtereffekte für Elemente angeben können, z. B. Unschärfe, Graustufen, Helligkeit, Farbversatz usw.

Die grundlegende Verwendung des CSS-Filters ist sehr einfach. Der CSS-Standard enthält einige Funktionen, die vordefinierte Effekte (Unschärfe, Helligkeit, Kontrast usw.) haben. Durch Angabe der Werte dieser Funktionen können wir die gewünschten Effekte erzielen :

/* 使用单个滤镜 (如果传入的参数是百分数,那么也可以传入对应的小数:40% --> 0.4)*/
filter: blur(5px);
filter: brightness(40%);
filter: contrast(200%);
filter: drop-shadow(16px 16px 20px blue);
filter: grayscale(50%);
filter: hue-rotate(90deg);
filter: invert(75%);
filter: opacity(25%);
filter: saturate(30%);
filter: sepia(60%);

/* 使用多个滤镜 */
filter: contrast(175%) brightness(3%);

/* 不使用任何滤镜 */
filter: none;
Nach dem Login kopieren

Offizielle Demo: MDN

Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!

Filter kommen in der täglichen Entwicklung sehr häufig vor, z. B. die Verwendung von drop-shadow, um mit blur</ Schatten zu unregelmäßigen Formen hinzuzufügen; Code >Um Hintergrundunschärfe, Milchglaseffekt usw. zu erzielen. <code>drop-shadow给不规则形状添加阴影;使用blur来实现背景模糊,以及毛玻璃效果等。

下面我们将进一步使用CSS filter实现一些动画效果,让网站交互更加酷炫,同时也加深对CSS filter的理解。一起开始吧!

( 下面要使用到的 动画 和 伪类 知识,在 CSS的N个编码技巧 中都有详细的介绍,这里就不重复了,有需要的朋友可以前往查看哦。 )

电影效果

滤镜中的brightness用于调整图像的明暗度。默认值是1;小于1时图像变暗,为0时显示为全黑图像;大于1时图像显示比原图更明亮。

我们可以通过调整 背景图的明暗度文字的透明度 ,来模拟电影谢幕的效果。

Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!

<div class="container">
  <div class="pic"></div>
  <div class="text">
    <p>如果生活中有什么使你感到快乐,那就去做吧</p>
    <br>
    <p>不要管别人说什么</p>
  </div>
</div>
Nach dem Login kopieren
.pic{
    height: 100%;
    width: 100%;
    position: absolute;
    background: url(&#39;./images/movie.webp&#39;) no-repeat;
    background-size: cover;
    animation: fade-away 2.5s linear forwards;    //forwards当动画完成后,保持最后一帧的状态
}
.text{
    position: absolute;
    line-height: 55px;
    color: #fff;
    font-size: 36px;
    text-align: center;
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
    opacity: 0;
    animation: show 2s cubic-bezier(.74,-0.1,.86,.83) forwards;
}
    
@keyframes fade-away {    //背景图的明暗度动画
    30%{
        filter: brightness(1);
    }
    100%{
        filter: brightness(0);
    }
}
@keyframes show{         //文字的透明度动画
    20%{
        opacity: 0;
    }
    100%{
        opacity: 1;
    }
}
Nach dem Login kopieren

模糊效果

在下面的单词卡片中,当鼠标hover到某一张卡片上时,其他卡片背景模糊,使用户焦点集中到当前卡片。

Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!

html结构:

<ul class="cards">
    <li class="card">
      <p class="title">Flower</p>
      <p class="content">The flowers mingle to form a blaze of color.</p>
    </li>
    <li class="card">
      <p class="title">Sunset</p>
      <p class="content">The sunset glow tinted the sky red.</p>
    </li>
    <li class="card">
      <p class="title">Plain</p>
      <p class="content">The winds came from the north, across the plains, funnelling down the valley. </p>
    </li>
 </ul>
Nach dem Login kopieren

实现的方式,是将背景加在.card元素的伪类上,当元素不是焦点时,为该元素的伪类加上滤镜。

.card:before{
    z-index: -1;
    content: &#39;&#39;;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    border-radius: 20px;
    filter: blur(0px) opacity(1);
    transition: filter 200ms linear, transform 200ms linear;
}
/*
     这里不能将滤镜直接加在.card元素,而是将背景和滤镜都加在伪类上。
     因为,父元素加了滤镜,它的子元素都会一起由该滤镜改变。
     如果滤镜直接加在.card元素上,会导致上面的文字也变模糊。
*/
Nach dem Login kopieren
//通过css选择器选出非hover的.card元素,给其伪类添加模糊、透明度和明暗度的滤镜 

.cards:hover > .card:not(:hover):before{    
  filter: blur(5px) opacity(0.8) brightness(0.8);
}
Nach dem Login kopieren
//对于hover的元素,其伪类增强饱和度,尺寸放大

.card:hover:before{
  filter: saturate(1.2);  
  transform: scale(1.05);
}
Nach dem Login kopieren

褪色效果

褪色效果可以打造出一种怀旧的风格。下面这组照片墙,我们通过sepia滤镜将图像基调转换为深褐色,再通过降低 饱和度saturate 和 色相旋转hue-rotate 微调,模拟老照片的效果。

Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!

.pic{
    border: 3px solid #fff;
    box-shadow: 0 10px 50px #5f2f1182;
    filter: sepia(30%) saturate(40%) hue-rotate(5deg);
    transition: transform 1s;
}
.pic:hover{
    filter: none;
    transform: scale(1.2) translateX(10px);
    z-index: 1;
}
Nach dem Login kopieren

灰度效果

怎样让网站变成灰色?在html元素上加上filter: grayscale(100%)即可。

grayscale(amount)函数将改变输入图像灰度。amount 的值定义了灰度转换的比例。值为 100% 则完全转为灰度图像,值为 0% 图像无变化。若未设置值,默认值是 0

Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!

融合效果

要使两个相交的元素产生下面这种融合的效果,需要用到的滤镜是blurcontrast

Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!

<div class="container">
  <div class="circle circle-1"></div>
  <div class="circle circle-2"></div>
</div>
Nach dem Login kopieren
.container{
  margin: 50px auto;
  height: 140px;
  width: 400px;
  background: #fff;   //给融合元素的父元素设置背景色
  display: flex;
  align-items: center;
  justify-content: center;
  filter: contrast(30);    //给融合元素的父元素设置contrast
}
.circle{
  border-radius: 50%;
  position: absolute;
  filter: blur(10px);    //给融合元素设置blur
}
.circle-1{
  height: 90px;
  width: 90px;
  background: #03a9f4;
  transform: translate(-50px);
  animation: 2s moving linear infinite alternate-reverse;
}
.circle-2{
  height: 60px;
  width: 60px;
  background: #0000ff;
  transform: translate(50px);
  animation: 2s moving linear infinite alternate;
}
 @keyframes moving {    //两个元素的移动
  0%{
    transform: translate(50px)
  }
  100%{
    transform: translate(-50px)
  }
}
Nach dem Login kopieren

实现融合效果的技术要点:

  • contrast滤镜应用在融合元素的父元素(.container)上,且父元素必须设置background

  • blur滤镜应用在融合元素(.circle)上。

blur设置图像的模糊程度,contrast

Im Folgenden werden wir den CSS-Filter weiterhin verwenden, um einige Animationseffekte zu erzielen, um die Website-Interaktion cooler zu gestalten und gleichzeitig unser Verständnis des CSS-Filters zu vertiefen. Fangen wir an!

(Das unten zu verwendende Animations- und Pseudoklassenwissen befindet sich in CSS N-Codes Dort sind detaillierte Einführungen in die Techniken 🎜, daher werde ich sie hier nicht wiederholen. Freunde in Not können sie sich ansehen)🎜

Filmeffekt

🎜 im Mit dem Helligkeitsfilter können Sie die Helligkeit des Bildes anpassen. Der Standardwert ist <code>1; wenn er kleiner als 1 ist, wird das Bild dunkler, wenn er 0 ist, wird ein vollständig schwarzes Bild angezeigt ; wenn er größer als 1 ist, erscheint das Bild heller als das Originalbild. 🎜🎜Wir können den Effekt eines Filmendes simulieren, indem wir die Helligkeit und Dunkelheit des Hintergrundbilds und die Transparenz des Textes anpassen. 🎜🎜Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!🎜
<div class="container">
  <div class="circle"></div>
  <div class="circle"></div>
  <div class="circle"></div>
  <div class="circle"></div>
  <div class="circle"></div>
</div>
Nach dem Login kopieren
Nach dem Login kopieren
.container {
  margin: 10px auto;
  height: 140px;
  width: 300px;
  background: #fff;       //父元素设置背景色
  display: flex;
  align-items: center;
  filter: contrast(30);   //父元素设置contrast
}
.circle {
  height: 50px;
  width: 60px;
  background: #1aa7ff;
  border-radius: 50%;
  position: absolute;
  filter: blur(20px);    //子元素设置blur
  transform: scale(0.1);
  transform-origin: left top;
}
.circle{
  animation: move 4s cubic-bezier(.44,.79,.83,.96) infinite;
}
.circle:nth-child(2) {
  animation-delay: .4s;
}
.circle:nth-child(3) {
  animation-delay: .8s;
}
.circle:nth-child(4) {
  animation-delay: 1.2s;
}
.circle:nth-child(5) {
  animation-delay: 1.6s;
}
@keyframes move{     //子元素的位移和尺寸动画
  0%{
    transform: translateX(10px) scale(0.3);
  }
  45%{
    transform: translateX(135px) scale(0.8);
  }
  85%{
    transform: translateX(270px) scale(0.1);
  }
}
Nach dem Login kopieren
Nach dem Login kopieren
< h2>Unschärfeeffekt🎜Wenn sich in der Wortkarte unten die Maus über einer bestimmten Karte befindet, wird der Hintergrund anderer Karten unscharf, sodass der Benutzer dies tun kann um sich auf die aktuelle Karte zu konzentrieren. 🎜🎜Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!🎜🎜< code>html-Struktur: 🎜
<div class="container">
  <span class="text">fantastic</span>
</div>
Nach dem Login kopieren
Nach dem Login kopieren
🎜Die Art und Weise, es zu implementieren, besteht darin, den Hintergrund zur Pseudoklasse des .card-Elements hinzuzufügen Hintergrund zur Pseudoklasse des Elements. 🎜
.container{
  margin-top: 50px;
  text-align: center;
  background-color: #000;
  filter: contrast(30);
}
.text{
  font-size: 100px;
  font-family: &#39;Gill Sans&#39;, &#39;Gill Sans MT&#39;, Calibri, &#39;Trebuchet MS&#39;, sans-serif;
  letter-spacing: -40px;
  color: #fff;
  animation: move-letter 4s linear forwards;  //forwards当动画完成后,保持最后一帧的状态
}
@keyframes move-letter{
  0% {
    opacity: 0;
    letter-spacing: -40px;
    filter: blur(10px);
  }
  25% {
    opacity: 1;
  }
  50% {
    filter: blur(5px);
  }
  100% {
    letter-spacing: 20px;
    filter: blur(2px);
  }
}
Nach dem Login kopieren
Nach dem Login kopieren
<div class="container">
  <img  src="images/moon.jpg" alt="Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!" >
  <img  src="images/moon.jpg" class="reflect" alt="Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!" >
</div>

<!--定义svg滤镜,这里使用的是feTurbulence滤镜-->
<svg width="0" height="0">
    <filter id="displacement-wave-filter">
    
      <!--baseFrequency设置0.01 0.09两个值,代表x轴和y轴的噪声频率-->  
      <feTurbulence baseFrequency="0.01 0.09">
        
        <!--这是svg动画的定义方式,通过动画不断改变baseFrequency的值,从而形成波动效果-->
        <animate attributeName="baseFrequency"
        dur="20s" keyTimes="0;0.5;1" values="0.01 0.09;0.02 0.13;0.01 0.09"
        repeatCount="indefinite" ></animate>
        
      </feTurbulence>
      <feDisplacementMap in="SourceGraphic" scale="10" /> 
    </filter>
</svg>
Nach dem Login kopieren
Nach dem Login kopieren
.container{
   height: 520px;
   width: 400px;
   display: flex;
   clip-path: inset(10px);
   flex-direction: column;
}
img{
  height: 50%;
  width: 100%;
}
.reflect {
  transform: translateY(-2px) scaleY(-1);
  //对模拟倒影的元素应用svg filter
  //url中对应的是上面svg filter的id
  filter: url(#displacement-wave-filter);  
}
Nach dem Login kopieren
Nach dem Login kopieren

Faded Effect

🎜Der Fade-Effekt kann einen nostalgischen Stil erzeugen. In der folgenden Reihe von Fotowänden verwenden wir den Filter Sepia, um den Ton des Bildes in Dunkelbraun umzuwandeln, und reduzieren dann die Sättigung saturate und drehen den Farbton hue-rotate</ code> Feinabstimmung, um den Effekt alter Fotos zu simulieren. 🎜🎜<img src="https://img.php.cn/upload/image/741/542/328/163124110441720Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!" title="163124110441720Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!" alt="Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!"/>🎜<div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:css;toolbar:false;">&lt;div&gt; &lt;p class=&quot;shaky&quot;&gt;Such a joyful night!&lt;/p&gt; &lt;/div&gt; &lt;svg width=&quot;0&quot; height=&quot;0&quot;&gt; &lt;filter id=&quot;displacement-text-filter&quot;&gt; &lt;!--定义feTurbulence滤镜--&gt; &lt;feTurbulence baseFrequency=&quot;0.02&quot; seed=&quot;0&quot;&gt; &lt;!--这是svg动画的定义方式,通过动画不断改变seed的值,形成抖动效果--&gt; &lt;animate attributeName=&quot;seed&quot; dur=&quot;1s&quot; keyTimes=&quot;0;0.5;1&quot; values=&quot;1;2;3&quot; repeatCount=&quot;indefinite&quot; &gt;&lt;/animate&gt; &lt;/feTurbulence&gt; &lt;feDisplacementMap in=&quot;SourceGraphic&quot; scale=&quot;10&quot; /&gt; &lt;/filter&gt; &lt;/svg&gt;</pre><div class="contentsignin">Nach dem Login kopieren</div></div><div class="contentsignin">Nach dem Login kopieren</div></div>< h2><strong>Graustufeneffekt</strong></h2>🎜Wie mache ich die Website grau? Fügen Sie einfach <code>filter: greyscale(100%) zum HTML-Element hinzu. 🎜🎜grayscale(amount)-Funktion ändert die Graustufen des Eingabebildes. Der Wert von amount definiert das Verhältnis der Graustufenkonvertierung. Wenn der Wert 100 % ist, wird das Bild vollständig in Graustufen umgewandelt, und wenn der Wert 0 % ist, bleibt das Bild unverändert. Wenn kein Wert festgelegt ist, ist der Standardwert 0. 🎜🎜Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!🎜

Mischeffekt

🎜Damit zwei sich überschneidende Elemente den folgenden Fusionseffekt erzeugen, sind die Filter Unschärfe und Kontrast erforderlich. 🎜🎜Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!🎜
.shaky{
  font-size: 60px;
  filter: url(#displacement-text-filter);   //url中对应的是上面svg filter的id
}
Nach dem Login kopieren
Nach dem Login kopieren
rrreee🎜 Technische Punkte zum Erzielen des Mischeffekts:🎜
  • 🎜Kontrast-Filter wird auf das übergeordnete Element von angewendet Das gemischte Elementelement (.container) und das übergeordnete Element müssen background festlegen. 🎜
  • 🎜Der blur-Filter wird auf das Blend-Element (.circle) angewendet. 🎜
🎜blur legt den Unschärfegrad des Bildes fest und contrast legt den Kontrast des Bildes fest. Wenn beide wie oben beschrieben kombiniert werden, entsteht ein magischer Fusionseffekt, und Sie können diese Schrift wie eine Formel verwenden. 🎜🎜Basierend auf diesem Fusionseffekt können wir einige interessante Interaktionsdesigns erstellen. 🎜
  • 加载动画:

Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!

htmlcss如下所示,这个动画主要通过控制子元素.circle的尺寸和位移来实现,但是由于父元素和子元素都满足 “融合公式” ,所以当子元素相交时,就出现了融合的效果。

<div class="container">
  <div class="circle"></div>
  <div class="circle"></div>
  <div class="circle"></div>
  <div class="circle"></div>
  <div class="circle"></div>
</div>
Nach dem Login kopieren
Nach dem Login kopieren
.container {
  margin: 10px auto;
  height: 140px;
  width: 300px;
  background: #fff;       //父元素设置背景色
  display: flex;
  align-items: center;
  filter: contrast(30);   //父元素设置contrast
}
.circle {
  height: 50px;
  width: 60px;
  background: #1aa7ff;
  border-radius: 50%;
  position: absolute;
  filter: blur(20px);    //子元素设置blur
  transform: scale(0.1);
  transform-origin: left top;
}
.circle{
  animation: move 4s cubic-bezier(.44,.79,.83,.96) infinite;
}
.circle:nth-child(2) {
  animation-delay: .4s;
}
.circle:nth-child(3) {
  animation-delay: .8s;
}
.circle:nth-child(4) {
  animation-delay: 1.2s;
}
.circle:nth-child(5) {
  animation-delay: 1.6s;
}
@keyframes move{     //子元素的位移和尺寸动画
  0%{
    transform: translateX(10px) scale(0.3);
  }
  45%{
    transform: translateX(135px) scale(0.8);
  }
  85%{
    transform: translateX(270px) scale(0.1);
  }
}
Nach dem Login kopieren
Nach dem Login kopieren
  • 酷炫的文字出场方式:

Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!

主要通过不断改变letter-spacingblur的值,使文字从融合到分开:

<div class="container">
  <span class="text">fantastic</span>
</div>
Nach dem Login kopieren
Nach dem Login kopieren
.container{
  margin-top: 50px;
  text-align: center;
  background-color: #000;
  filter: contrast(30);
}
.text{
  font-size: 100px;
  font-family: &#39;Gill Sans&#39;, &#39;Gill Sans MT&#39;, Calibri, &#39;Trebuchet MS&#39;, sans-serif;
  letter-spacing: -40px;
  color: #fff;
  animation: move-letter 4s linear forwards;  //forwards当动画完成后,保持最后一帧的状态
}
@keyframes move-letter{
  0% {
    opacity: 0;
    letter-spacing: -40px;
    filter: blur(10px);
  }
  25% {
    opacity: 1;
  }
  50% {
    filter: blur(5px);
  }
  100% {
    letter-spacing: 20px;
    filter: blur(2px);
  }
}
Nach dem Login kopieren
Nach dem Login kopieren

水波效果

filter还可以通过 URL 链接到 SVG 滤镜元素,SVG滤镜元素MDN

下面的水波纹效果就是基于 SVG 的feTurbulence滤镜实现的,原理参考了 说说SVG的feTurbulence滤镜SVG feTurbulence滤镜深入介绍,有兴趣的朋友可以深入阅读。

feTurbulence滤镜借助Perlin噪声算法模拟自然界真实事物那样的随机样式。它接收下面5个属性:

  • baseFrequency表示噪声的基本频率参数,频率越高,噪声越密集。
  • numOctaves就表示倍频的数量,倍频的数量越多,噪声看起来越自然。
  • seed属性表示feTurbulence滤镜效果中伪随机数生成的起始值,不同数量的seed不会改变噪声的频率和密度,改变的是噪声的形状和位置。
  • stitchTiles定义了Perlin噪声在边框处的行为表现。
  • type属性值有fractalNoiseturbulence,模拟随机样式使用turbulence

Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!

在这个例子,两个img标签使用同一张图片,将第二个img标签使用scaleY(-1)实现垂直方向的镜像翻转,模拟倒影。

并且,对倒影图片使用feTurbulence滤镜,通过动画不断改变feTurbulence滤镜的baseFrequency值实现水纹波动的效果。

<div class="container">
  <img  src="images/moon.jpg" alt="Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!" >
  <img  src="images/moon.jpg" class="reflect" alt="Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!" >
</div>

<!--定义svg滤镜,这里使用的是feTurbulence滤镜-->
<svg width="0" height="0">
    <filter id="displacement-wave-filter">
    
      <!--baseFrequency设置0.01 0.09两个值,代表x轴和y轴的噪声频率-->  
      <feTurbulence baseFrequency="0.01 0.09">
        
        <!--这是svg动画的定义方式,通过动画不断改变baseFrequency的值,从而形成波动效果-->
        <animate attributeName="baseFrequency"
        dur="20s" keyTimes="0;0.5;1" values="0.01 0.09;0.02 0.13;0.01 0.09"
        repeatCount="indefinite" ></animate>
        
      </feTurbulence>
      <feDisplacementMap in="SourceGraphic" scale="10" /> 
    </filter>
</svg>
Nach dem Login kopieren
Nach dem Login kopieren
.container{
   height: 520px;
   width: 400px;
   display: flex;
   clip-path: inset(10px);
   flex-direction: column;
}
img{
  height: 50%;
  width: 100%;
}
.reflect {
  transform: translateY(-2px) scaleY(-1);
  //对模拟倒影的元素应用svg filter
  //url中对应的是上面svg filter的id
  filter: url(#displacement-wave-filter);  
}
Nach dem Login kopieren
Nach dem Login kopieren

抖动效果

在上面的水波动画中改变的是baseFrequency值,我们也通过改变seed的值,实现文字的抖动效果。

Tipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!

<div>
  <p class="shaky">Such a joyful night!</p>
</div>
<svg width="0" height="0">
    <filter id="displacement-text-filter">
    
      <!--定义feTurbulence滤镜-->
      <feTurbulence baseFrequency="0.02" seed="0">
      
       <!--这是svg动画的定义方式,通过动画不断改变seed的值,形成抖动效果-->
        <animate attributeName="seed"
        dur="1s" keyTimes="0;0.5;1" values="1;2;3"
        repeatCount="indefinite" ></animate>
      </feTurbulence>
      <feDisplacementMap in="SourceGraphic" scale="10" /> 
    </filter>
  </svg>
Nach dem Login kopieren
Nach dem Login kopieren
.shaky{
  font-size: 60px;
  filter: url(#displacement-text-filter);   //url中对应的是上面svg filter的id
}
Nach dem Login kopieren
Nach dem Login kopieren

原文地址:https://juejin.cn/post/7002829486806794276

作者:Alaso

更多编程相关知识,请访问:编程视频!!

Das obige ist der detaillierte Inhalt vonTipps zur Verwendung von CSS-Filtern, um Ihre Website cooler zu machen, es lohnt sich, sie zu sammeln!. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:掘金--Alaso
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