Heim > Web-Frontend > CSS-Tutorial > Wie behebe ich ein responsives Hintergrundbild im Vollbildmodus, das abgeschnitten wird?

Wie behebe ich ein responsives Hintergrundbild im Vollbildmodus, das abgeschnitten wird?

Mary-Kate Olsen
Freigeben: 2024-11-16 13:57:03
Original
506 Leute haben es durchsucht

How To Fix a Full-Screen Responsive Background Image That Gets Cropped?

Reaktionsfähiges Hintergrundbild im Vollbildmodus

Das Erstellen eines reaktionsfähigen Hintergrundbilds im Vollbildmodus ist eine wesentliche Fähigkeit im modernen Webdesign. In diesem Leitfaden werden wir ein Problem mit einem Vollbild-Hintergrundbild beheben und alternative Lösungen untersuchen.

Fehlerhafter Code

<div class="main-header">
  <div class="row">
    <div class="large-6 large-offset-6 columns">
      <h1>BleepBleeps</h1>
      <h3>A family of little friends<br>that make parenting easier</h3>
    </div>
  </div>
</div>
Nach dem Login kopieren
.main-header {
  background-image: url(../img/bb-background2.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  width: 100%;
  height: 100%;
}
Nach dem Login kopieren

Problemanalyse

Der bereitgestellte Code verwendet die Eigenschaft „background-size: cover“, die das Bild so skaliert, dass es den Container abdeckt. Allerdings wird das Bild außerhalb des Bildschirms abgeschnitten, was zu einer unvollständigen Anzeige führt.

Alternative Lösungen

1. Absolute Positionierung mit CSS

#bg {
  position: fixed;
  top: 0;
  left: 0;
  min-width: 100%;
  min-height: 100%;
}
Nach dem Login kopieren

2. Proportionale Skalierung mit CSS-Medienabfragen

.bg {
  min-height: 100%;
  max-width: 1024px;
  width: 100%;
  height: auto;
  position: fixed;
  top: 0;
  left: 0;
}

@media screen and (max-width: 1024px) {
  .bg {
    left: 50%;
    margin-left: -512px;
  }
}
Nach dem Login kopieren

3. jQuery Resize Listener

$(window).load(function() {
  var $bg = $("#bg");
  var aspectRatio = $bg.width() / $bg.height();

  function resizeBg() {
    if ((theWindow.width() / theWindow.height()) < aspectRatio) {
      $bg.addClass('bgheight');
    } else {
      $bg.addClass('bgwidth');
    }
  }

  theWindow.resize(resizeBg).trigger("resize");
});
Nach dem Login kopieren

Herausforderungen bei der mobilen Anzeige überwinden

Damit div> auf Mobilgeräten über dem Vollbildbild angezeigt werden kann, sollten Sie die Verwendung von Flexbox oder CSS Grid und absolute Positionierung in Betracht ziehen.

Das obige ist der detaillierte Inhalt vonWie behebe ich ein responsives Hintergrundbild im Vollbildmodus, das abgeschnitten wird?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage