五种css的方式实现瀑布流布局效果
代码语言:html
所属分类:瀑布流
代码描述:五种css的方式实现瀑布流布局效果
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<style>
/* --- Masonry --- */
[value="masonry"]:checked ~ main {
display: grid;
grid-template-rows: masonry;
grid-template-columns: repeat(auto-fill, minmax(12rem, 1fr));
gap: 1rem;
}
/* --- Grid --- */
[value="grid"]:checked ~ main {
display: grid;
grid-template-rows: auto;
grid-template-columns: repeat(auto-fill, minmax(12rem, 1fr));
gap: 1rem;
}
/* --- Multicolumn --- */
[value="multicolumn"]:checked ~ main {
display: block;
columns: 12rem;
gap: 1rem;
}
[value="multicolumn"]:checked ~ main figure {
margin-bottom: 1rem;
break-inside: avoid;
}
/* --- Flexbox, row direction --- */
[value="flexbox"]:checked ~ main {
display: flex;
flex-wrap: wrap;
gap: 1rem;
}
[value="flexbox"]:checked ~ main figure {
flex: 1 1 12rem;
}
/* --- Flexbox, column direction --- */
[value="flexbox2"]:checked ~ main {
display: flex;
flex-wrap: wrap;
flex-direction: column;
max-height: 200vh;
justify-content: start;
gap: 1rem;
}
[value="flexbox2"]:checked ~ main figure {
width: 100%;
max-width: 16rem;
}
/* --- The rest of the styling --- */
* {
box-sizing: border-box;
}
body {
font-family: avenir, roboto, helvetica, sans-serif;
margin: 2rem calc(2vw + 2rem);
}
main {
margin: 2rem 0;
}
img {
width: 100%;
display: block;
border-radius: 0 0 1rem 1rem;
}
figure {
margin: 0;
}
figcaption {
padding: 0.5rem 1rem 0.4rem;
background: #ddd;
color: #333;
border-radius: 1rem 1rem 0 0;
text-align: end;
}
h1 {
margin: 0;
}
h2 {
margin: 0;
}
h3 {
margin: 0.5rem 0 0;
font-size: 1rem;
}
aside {
margin: 6rem 0;
max-width: 80ch;
padding: 2rem 2rem 1rem;
border: 1px solid #000;
}
p {
margin: 1rem 0;
color: #444;
font-wei.........完整代码请登录后点击上方下载按钮下载查看
















网友评论0