Heim  >  Fragen und Antworten  >  Hauptteil

So wenden Sie CSS-Filter auf Hintergrundbilder an

<p>Ich habe eine JPEG-Datei, die ich als Hintergrundbild für meine Suchseite verwende, und ich verwende CSS, um sie festzulegen, weil ich in einem Backbone.js-Kontext arbeite: </p> <pre class="brush:php;toolbar:false;">background-image: url("whatever.jpg");</pre> <p>Ich möchte<em>einen CSS 3-Unschärfefilter nur</em>auf den Hintergrund anwenden, bin mir aber nicht sicher, wie ich nur dieses Element formatieren soll. Wenn ich es versuche: </p> <pre class="brush:php;toolbar:false;">-webkit-filter: Blur(5px); -moz-filter: Unschärfe(5px); -o-filter: Unschärfe (5px); -ms-filter: Unschärfe(5px); Filter: Unschärfe(5px);</pre> <p>Direkt unter <code>background-image</code> in meinem CSS wird die gesamte Seite formatiert, nicht nur der Hintergrund. Gibt es eine Möglichkeit, einfach das Bild auszuwählen und einen Filter darauf anzuwenden? Gibt es alternativ eine Möglichkeit, die Unschärfe für alle anderen Elemente auf der Seite zu deaktivieren? </p>
P粉675258598P粉675258598393 Tage vor437

Antworte allen(2)Ich werde antworten

  • P粉521697419

    P粉5216974192023-08-24 12:52:20

    消除对额外元素的需求,同时使内容适合文档流,而不是像其他解决方案那样固定/绝对。

    使用实现

    .content {
      /* this is needed or the background will be offset by a few pixels at the top */
      overflow: auto;
      position: relative;
    }
    
    .content::before {
      content: "";
      position: fixed;
      left: 0;
      right: 0;
      z-index: -1;
    
      display: block;
      background-image: url('https://i.imgur.com/lL6tQfy.png');
      background-size:cover;
      width: 100%;
      height: 100%;
    
      -webkit-filter: blur(5px);
      -moz-filter: blur(5px);
      -o-filter: blur(5px);
      -ms-filter: blur(5px);
      filter: blur(5px);
    }
    <div class="content">
    Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.
    </div>

    编辑如果您有兴趣删除边缘的白色边框,请使用110%的宽度和高度以及-5的左侧和顶部%。这会稍微放大你的背景 - 但不应该有纯色从边缘渗入。感谢查德·福塞特的建议。

    .content {
      /* this is needed or the background will be offset by a few pixels at the top */
      overflow: auto;
      position: relative;
    }
    
    .content::before {
      content: "";
      position: fixed;
      top: -5%;
      left: -5%;
      right: -5%;
      z-index: -1;
    
      display: block;
      background-image: url('https://i.imgur.com/lL6tQfy.png');
      background-size:cover;
      width: 110%;
      height: 110%;
    
      -webkit-filter: blur(5px);
      -moz-filter: blur(5px);
      -o-filter: blur(5px);
      -ms-filter: blur(5px);
      filter: blur(5px);
    }
    <div class="content">
    Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.
    </div>

    Antwort
    0
  • P粉316423089

    P粉3164230892023-08-24 10:25:04

    看看这个

    您必须使用两个不同的容器,一个用于背景图像,另一个用于您的内容。

    在示例中,我创建了两个容器:.background-image.content

    两者都放置为position:fixedleft:0;右:0;。显示它们的差异来自于为元素设置不同的 z-index 值。

    .background-image {
      position: fixed;
      left: 0;
      right: 0;
      z-index: 1;
      display: block;
      background-image: url('https://i.imgur.com/lL6tQfy.png');
      width: 1200px;
      height: 800px;
      -webkit-filter: blur(5px);
      -moz-filter: blur(5px);
      -o-filter: blur(5px);
      -ms-filter: blur(5px);
      filter: blur(5px);
    }
    
    .content {
      position: fixed;
      left: 0;
      right: 0;
      z-index: 9999;
      margin-left: 20px;
      margin-right: 20px;
    }
    <div class="background-image"></div>
    <div class="content">
      <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Duis aliquam erat in ante malesuada, facilisis semper nulla semper. Phasellus sapien neque, faucibus in malesuada quis, lacinia et libero. Sed sed turpis tellus. Etiam ac aliquam tortor, eleifend
        rhoncus metus. Ut turpis massa, sollicitudin sit amet molestie a, posuere sit amet nisl. Mauris tincidunt cursus posuere. Nam commodo libero quis lacus sodales, nec feugiat ante posuere. Donec pulvinar auctor commodo. Donec egestas diam ut mi adipiscing,
        quis lacinia mauris condimentum. Quisque quis odio venenatis, venenatis nisi a, vehicula ipsum. Etiam at nisl eu felis vulputate porta.</p>
      <p>Fusce ut placerat eros. Aliquam consequat in augue sed convallis. Donec orci urna, tincidunt vel dui at, elementum semper dolor. Donec tincidunt risus sed magna dictum, quis luctus metus volutpat. Donec accumsan et nunc vulputate accumsan. Vestibulum
        tempor, erat in mattis fringilla, elit urna ornare nunc, vel pretium elit sem quis orci. Vivamus condimentum dictum tempor. Nam at est ante. Sed lobortis et lorem in sagittis. In suscipit in est et vehicula.</p>
    </div>

    Antwort
    0
  • StornierenAntwort