Heim  >  Artikel  >  Web-Frontend  >  So implementieren Sie das klassische dreispaltige Layout von CSS

So implementieren Sie das klassische dreispaltige Layout von CSS

php中世界最好的语言
php中世界最好的语言Original
2018-01-30 10:00:111427Durchsuche

Dieses Mal zeige ich Ihnen, wie Sie das klassische dreispaltige Layout von CSS implementieren. Was sind die Vorsichtsmaßnahmen für die Implementierung des klassischen dreispaltigen Layouts von CSS? ein Blick.

Dieser Artikel stellt das klassische CSS-Layout mit drei Spalten vor. Teilen Sie es mit allen und machen Sie sich eine Notiz:

Dreispaltiges Layout , ist beidseitig fest und in der Mitte adaptiv. Dreispaltiges Layout ist in der Entwicklung sehr verbreitet

1. Float-Layout

Das einfachste dreispaltige Layout ist die Verwendung von Float als Layout. Zeichnen wir zunächst die linke und rechte Spalte:

<style>
  .left {
    float: left;
    width: 100px;
    height: 200px;
    background-color: red;
  }
 
  .right {
    float: right;
    width: 100px;
    height: 200px;
    background-color: yellow;
  }
</style>
   
  <div class="container">
    <div class="left"></div>
    <div class="right"></div>
    <div class="main"></div>
  </div>

Als nächstes schauen wir uns an, wie mit der mittleren Spalte umgegangen wird. Wir wissen, dass Float-Elemente aus dem Dokumentenfluss ausbrechen und andere Boxen dieses Element ignorieren. (Aber der Text in anderen Feldern macht immer noch Platz für dieses Element und umgibt es.) Zu diesem Zeitpunkt müssen Sie also nur ein normales Div im Container hinzufügen, das links und rechts ignoriert und den gesamten Container ausfüllt. Darüber hinaus kann der Rand nach links und rechts aus dem Raum herausfließen:

<style>
   .left {
     float: left;
     width: 100px;
     height: 200px;
     background-color: red;
   }
  
   .right {
     float: right;
     width: 100px;
     height: 200px;
     background-color: yellow;
   }
  
   .main {
     background-color: green;
     height: 200px;
     margin-left: 120px;
     margin-right: 120px;
   }
  
   .container {
     border: 1px solid black;
   }
  
   <div class="container">
   <div class="left"></div>
   <div class="right"></div>
   <div class="main"></div>
   </div>

Vorteile: Einfach

Nachteile: Der mittlere Teil wird zuletzt geladen, was sich auf das Erlebnis auswirkt, wenn Es gibt viele Inhalte

2. BFC-Regeln

BFC-Regeln (Block Formatting Context) legen fest, dass BFC keine schwebenden Elemente überlappen. Wenn Sie also das Hauptelement als BFC-Element festlegen:

<style>
  .left {
    float: left;
    width: 100px;
    height: 200px;
    background-color: red;
  }
 
  .right {
    float: right;
    width: 100px;
    height: 200px;
    background-color: yellow;
  }
 
  .main {
    background-color: green;
    height: 200px;
    overflow: hidden;
  }
 
  <div class="container">
    <div class="left"></div>
    <div class="right"></div>
    <div class="main"></div>
  </div>

3. Holy Grail-Layout

Der Kern des Holy Grail-Layouts besteht darin, dass die linke, mittlere und rechte Spalte vorhanden sind Alles schwebte durch Float. Passen Sie es dann mit negativer Marge an.

Der erste Schritt besteht darin, einen Blick auf das Grundlayout zu werfen

<style>
    .left {
        float: left;
        width: 100px;
        height: 200px;
        background-color: red;
    }
 
    .right {
        float: left;
        width: 100px;
        height: 200px;
        background-color: yellow;
    }
 
    .main {
        float: left;
        width: 100%;
        height: 200px;
        background-color: blue;
    }
</style>
<body>
    <div class="container">
        <div class="main"></div>
        <div class="left"></div>
        <div class="right"></div>
    </div>
</body>

Der Effekt, den Sie zu diesem Zeitpunkt sehen, ist: Die linke und rechte Spalte werden in die zweite Zeile gequetscht. Dies liegt daran, dass die Breite von main 100 % beträgt. Als nächstes fügen wir die linke, mittlere und rechte Spalte in einer Zeile ein, indem wir die Ränder der linken und rechten Spalte anpassen:

.left {
    float: left;
    width: 100px;
    height: 200px;
    margin-left: -100%;
    background-color: red;
}
 
.right {
    float: left;
    width: 100px;
    height: 200px;
    margin-left: -100px;
    background-color: yellow;
}

Der zweite Schritt besteht darin, den linken Rand von links auf -100 % festzulegen. . Diese linke Spalte wird an den Anfang der ersten Zeile verschoben. Setzen Sie dann den linken Rand von rechts auf den negativen Wert seiner Breite: -100px, und die rechte Spalte wird ebenfalls in die gleiche Zeile wie die linke und mittlere Spalte verschoben:

Wir sind jedoch noch nicht fertig Dennoch versuchen wir, etwas Text zum Haupttext hinzuzufügen:

<body>
    <div class="container">
        <div class="main">fjlskdjflkasjdfljasdljlsjdljsdjflksadj</div>
        <div class="left"></div>
        <div class="right"></div>
    </div>
</body>

Sie können sehen, dass der Text unterdrückt wird, und wir müssen dieses Problem als nächstes lösen.

Der dritte Schritt besteht darin, dem Container eine Polsterung zu geben. Die Polsterung sollte genau der Breite der linken und rechten Spalte entsprechen:

.container {
    padding-left: 100px;
    padding-right: 100px;
}

Die Ergebnisse sehen Sie unter Diesmal sind die linken, mittleren und drei rechten Spalten alle verkleinert, aber der Text wird immer noch unterdrückt.

Der vierte Schritt besteht darin, der linken und rechten Spalte ein relatives Layout hinzuzufügen und sie dann durch Festlegen der linken und rechten Werte nach außen zu verschieben:

.left {
    float: left;
    width: 100px;
    height: 200px;
    margin-left: -100%;
    position: relative;
    left: -100px;
    background-color: red;
}
 
.right {
    float: left;
    width: 100px;
    height: 200px;
    margin-left: -100px;
    position: relative;
    right: -100px;
    background-color: yellow;
}

Das war's, Sie sind fertig :

Ich glaube, dass Sie die Methoden beherrschen, nachdem Sie diese Fälle gelesen haben. Weitere spannende Informationen finden Sie in anderen verwandten Artikeln auf der chinesischen PHP-Website!

Verwandte Lektüre:

So erstellen Sie einen Kreisanimationseffekt in HTML5

In h5 sollte die mobile Seite sein vergrößert So implementieren Sie

So verwenden Sie H5 Canvas, um ein dynamisches 3D-Diagramm zu implementieren

So verwenden Sie die FileReader-Distribution von H5 zum Lesen von Dateien und seine Methodeneinführung

Das obige ist der detaillierte Inhalt vonSo implementieren Sie das klassische dreispaltige Layout von CSS. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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