Heim > Web-Frontend > CSS-Tutorial > Wie implementiert man das Bildfass-Layout in CSS3? (mit Code)

Wie implementiert man das Bildfass-Layout in CSS3? (mit Code)

青灯夜游
Freigeben: 2020-07-14 10:00:58
nach vorne
2975 Leute haben es durchsucht

In diesem Artikel erfahren Sie anhand von Codebeispielen, wie Sie CSS3 verwenden, um das Bildfass-Layout zu implementieren. Es hat einen gewissen Referenzwert. Freunde in Not können sich darauf beziehen. Ich hoffe, es wird für alle hilfreich sein.

Wie implementiert man das Bildfass-Layout in CSS3? (mit Code)

Ein Layout mit gleicher Höhe, aber unterschiedlichen Breiten wird als Barrel-Layout bezeichnet. Es weist mehrere Besonderheiten auf: Die Bilder in jeder Zeile sind sehr konsistent; die Bilder in jeder Zeile sind vollständig.

Ideen:

1. Stellen Sie die Höhe des Bildes ein und überschreiten Sie den Zeilenumbruch
3 : 1 für alle Bilder; um die gesamte Zeile zu füllen
4. Object-fit: cover für alle Bilder festlegen, um das Problem der Bildverformung zu lösen
5. Container: nach Pseudo-Klasse setzt Flex-Grow: 9999 ; und der Wert ist hoch genug, um das Problem zu lösen, wenn die Anzahl der Bilder in der letzten Reihe gering ist. Immer noch voller ganzer Reihen und zu flach und lang

Der Code lautet wie folgt, kopieren und verwenden :

<!DOCTYPE html>
    <script>
        window.navigator.appVersion.indexOf(&#39;Trident&#39;) != -1 && alert(&#39;请用谷歌或火狐新版打开!&#39;);
    </script>
<html>
<head>
    <meta charset="utf-8">
    <title></title>
    <style type="text/css">
        *{
            margin: 0;
        }
        body{
            padding: 50px 0;
            overflow-x: hidden;
        }
        .wrap{
            display: flex;
            flex-wrap: wrap;
        }
        .wrap img{
            margin: 3px;
            padding: 5px;
            height: 200px;
            background: #ccc;
            flex-grow: 1;
            object-fit: cover;
            transition: .3s;
        }
        .wrap:after{
            display: block;
            content: &#39;&#39;;
            flex-grow: 9999;
        }
        .wrap img:hover{
            transform: scale(1.2);
            box-shadow: 0 0 20px #fff;
            z-index: 9999;
        }
    </style>
</head>
<body>
    <div class="wrap"></div>
    <script>
        var wrap = document.querySelector(&#39;.wrap&#39;);
        var src = [&#39;img/1.jpg&#39;,&#39;img/2.jpg&#39;,&#39;img/3.jpg&#39;,&#39;img/4.jpg&#39;,&#39;img/5.jpg&#39;]
        for(var i=0; i<Math.floor(Math.random()*10+30); i++){
            var img = document.createElement(&#39;img&#39;);
            img.src = src[Math.floor(Math.random()*5)];
            wrap.appendChild(img);
        }
    </script>
</body>
</html>
Nach dem Login kopieren

Rendering:


Wie implementiert man das Bildfass-Layout in CSS3? (mit Code)

Weitere coole CSS3-, HTML5- und Javascript-Spezialeffektcodes finden Sie unter:

js-Spezialeffektsammlung !

Das obige ist der detaillierte Inhalt vonWie implementiert man das Bildfass-Layout in CSS3? (mit Code). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:cnblogs.com
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