五种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