html - 如何将行添加到响应式网格

标签 html css responsive-design row grid-layout

我正在尝试创建一个响应式网格布局,但是到目前为止我得到的是 4x2 网格,当我尝试添加更多行时它总是出错。我设法让正方形旋转,我有一个 4x2 网格,我想制作一个 4x5 网格。但是我似乎无法用 div 实现它的布局。

谁能告诉我如何解决这个问题并使它成为 4x5 网格,因为我很困惑。我的代码如下。请展示你的答案:)

CSS

.trigger{
width:64%;
height:64%;
background-color:white; 
}
.hover-img, hover-img.hover_effect  {
background-color:white;
position: relative;
width: 200px;
height: 200px;
-webkit-transition: all 1s ease-in-out;
-moz-transition: all 1s ease-in-out;
-ms-transition: all 1s ease-in-out;
-o-transition: all 1s ease-in-out;
transition: all 1s ease-in-out;
-webkit-transform: rotateY(180deg);
transform: rotateY(180deg);
-webkit-transform-style: preserve-3d;
text-align: center;
font-size: 0;
-webkit-user-select: none;
-webkit-touch-callout: none; 
border-style: solid;
border-width: 1px;
border-color: #4595ff;
}
.trigger:hover > .hover-img {
-webkit-transform:rotateY(360deg);
-moz-transform:rotateY(360deg);
-ms-transform:rotateY(360deg);
-o-transform:rotateY(360deg);
transform:rotateY(360deg);
font-size:14px;
color:white;
}

.img1 {
background-size: 100% 100%;
background-repeat: no-repeat; 
}
.img1:hover{
background-size: 100% 100%;
background-repeat: no-repeat;
}

.img2 {
background-size: 100% 100%;
background-repeat: no-repeat;
}
.img2:hover{
background-size: 100% 100%;
background-repeat: no-repeat;
}

.img3 {
background-size: 100% 100%;
background-repeat: no-repeat;
} 
.img3:hover{
background-size: 100% 100%;
background-repeat: no-repeat;
}
.img4 {
background-size: 100% 100%;
background-repeat: no-repeat;
}
.img4:hover{
background-size: 100% 100%;
background-repeat: no-repeat;
}
.img5 {
background-size: 100% 100%;
background-repeat: no-repeat;
}
.img5:hover{
background-size: 100% 100%;
background-repeat: no-repeat;
}
.img6 {
background-size: 100% 100%;
background-repeat: no-repeat;
}
.img6:hover{
background-size: 100% 100%;
background-repeat: no-repeat;
}

#container{
width: 100%;
display:flex;
justify-content: space-around;
flex-wrap:nowrap;
}

.column{
float: left;
width: auto;
font-size: 12px;
}

HTML

<div id="container">
<div class="column">
<div class="trigger">
  <div tabindex="0" class="maincontent hover-img img1">
  </div>
</div>
<div class="trigger">
  <div tabindex="0" class="maincontent hover-img img2">
  </div>
</div>
</div>
<div  class="column">
<div class="trigger">
<div tabindex="0" class="maincontent hover-img img3"></div>
</div>
<div class="trigger">
  <div tabindex="0" class="maincontent hover-img img4">
  </div>
</div>
</div>
<div  class="column">
<div class="trigger">
<div tabindex="0" class="maincontent hover-img img5">
</div>
</div>
<div class="trigger">
<div tabindex="0" class="maincontent hover-img img6">
</div>
</div>
</div>
<div  class="column">
<div class="trigger">
<div tabindex="0" class="maincontent hover-img img5">
</div>
</div>
<div class="trigger">
<div tabindex="0" class="maincontent hover-img img6">
</div>
</div>
</div>
</div>

最佳答案

更新 由于 OP 想要使用 flex 属性来创建他的列,这里是更新的代码(html 结构与我之前的回答相同,只是 css 发生了变化。flex属性应该在 row div,而不是 container div) 这是一个三行的 fiddle :https://jsfiddle.net/Snowbell92/4dnjwzj6/

HTML:

<div id="container">
<div class="row">
  <div class="trigger">
    <div tabindex="0" class="maincontent hover-img img1"> </div>
  </div>
  <div class="trigger">
    <div tabindex="0" class="maincontent hover-img img2"> </div>
  </div>
  <div class="trigger">
<div tabindex="0" class="maincontent hover-img img3"></div>
  </div>
  <div class="trigger">
<div tabindex="0" class="maincontent hover-img img4"> </div>
  </div>
</div> <!--keep repeating the rows-->
</div>

和css(display: flex.container移动到.row)

.row{
display: flex;
}

如果您想了解更多关于 flexbox 属性的信息,请查看关于它的精彩 css-tricks 文章:http://css-tricks.com/snippets/css/a-guide-to-flexbox/

/*************************************************** ***************************/

您必须将 添加到包含 中,然后您就可以根据需要添加任意数量的行,而不会出现任何复杂情况。 html 将如下所示:

<div class="row"> <!--this is the row that contains your columns.-->
   <div class="column"><p> some stuff. you can even use trigger div here for your purpose. and keep duplicating it for as many columns as you need. </div>
   <div class="column"><p> some stuff. you can even use trigger div here for your purpose. and keep duplicating it for as many columns as you need. </div>  
</div> <!--row ends here. for another row, just use this whole thing again.-->

在此处检查引导网格模板以查看网格的运行方式:http://getbootstrap.com/examples/grid/

关于html - 如何将行添加到响应式网格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28427184/

相关文章:

javascript - 如何在第二页创建一个按钮?

javascript - 托管站点缺少本地 html 文件中的元素

javascript - PDF.js 2.0.943 不在浏览器中呈现 PDF

javascript - 如何选择颜色,将其填充到使用fabric.js在 Canvas 中上传的选定图像中?

html - 覆盖动画的 CSS 类不起作用

html - Safari 选择/下拉选项未与输入标签对齐

CSS 列错误——5 列只显示 4(带图片)

html - 显示 : inline-block not working. 如何让它工作?

javascript - 滚动时移动菜单消失

css - 使用 CSS 缩放图像