- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
这里是我的起点:http://jsfiddle.net/Vercingetorix333/7b2L25a5/2/
如您所见,容器两端的间距( flex 尺寸:10)远大于内容之间的间距( flex 尺寸:2.5)。当用户减小 html 窗口的大小时,元素最终会换行到第二行(如预期的那样)。
但是我想做的是设置第一个窗口调整断点/响应因子,这样当内容移动到第二行时(可能使用 @media....
css?)它一次性获取最右边的两个内容 div。
然后我希望容器中的每一行看起来像这样:
大缓冲区 - 内容 - 小缓冲区 - 内容 - 大缓冲区
我可以只用 css 做这个吗?或者我需要一些 javascript 吗?
编辑:从 Fiddle 添加我的代码(为了后代)。
HTML
<div class="outer_container">
<div class="outer_buffer"></div>
<div class="content">Some Content</div>
<div class="inner_buffer"></div>
<div class="content">Some Content</div>
<div class="inner_buffer"></div>
<div class="content">Some Content</div>
<div class="inner_buffer"></div>
<div class="content">Some Content</div>
<div class="outer_buffer"></div>
</div>
CSS
.outer_container{
display: flex;
flex-wrap: wrap;
justify-content: center;
}
.outer_buffer{
flex-grow: 10;
}
.inner_buffer{
flex-grow: 2.5;
}
.content{
width: 50px;
border: solid 1px red;
}
最佳答案
你可以像这个答案那样做。我使用两组大(flex-grow 10)和小(flex-grow 2.5)缓冲区 div
作为第一个和第二个窗口调整断点,我已经系统地分配了 display: none
一次设置为一组,以便为每个 @media
查询断点只显示一组大小缓冲区 div
。我正在使用两个容器 div
并且每个容器 div
有两个内容 div
并且在第一个窗口调整大小 @media
query break-point 将右边的容器移到第二行。实际上,它会根据您想要的结果一次性获取最右边的两个内容 div
。
请查看我的答案的编辑部分(下方),通过使用 CSS 伪元素(即 :after
和 :before
)以最少的 HTML 标记完成它。
At first @media query break-point the result look like this:
large buffer (10) - content - small buffer (2.5) - content - large buffer (10)
large buffer (10) - content - small buffer (2.5) - content - large buffer (10)
您需要做的就是根据 .content
大小计算 CSS @media
查询断点的 max-width
解决方案.
例如:如果将 .content
的 width
设置为 200px
,则:
1st @media query break point of max-width is: 4 x 200px = 800px
2nd @media query break point of max-width is: 2 x 200px = 400px
Example: JSFiddle - DEMO
.wrapper {
display: flex;
flex-wrap: wrap;
justify-content: center;
}
.container {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
flex-grow: 2.5;
}
.content {
width: 50px;
border: solid 1px red;
}
.lg {
flex-grow: 10;
}
.sm {
flex-grow: 2.5;
}
.w-buffer {
display: block;
}
.c-buffer {
display: none;
}
@media (max-width: 224px) {
.wrapper {
display: block;
}
.container {
justify-content: center;
flex-grow: 0;
}
.w-buffer {
display: none;
}
.c-buffer {
display: block;
}
}
@media (max-width: 120px) {
.wrapper {
display: flex;
}
.w-buffer, .c-buffer {
display: none;
}
}
<div class="wrapper">
<div class="w-buffer lg"></div>
<div class="container">
<div class="c-buffer lg"></div>
<div class="content">Some Content</div>
<div class="c-buffer sm"></div>
<div class="content">Some Content</div>
<div class="c-buffer lg"></div>
</div>
<div class="w-buffer sm"></div>
<div class="container">
<div class="c-buffer lg"></div>
<div class="content">Some Content</div>
<div class="c-buffer sm"></div>
<div class="content">Some Content</div>
<div class="c-buffer lg"></div>
</div>
<div class="w-buffer lg"></div>
</div>
您还可以使用 CSS Pseudo-elements (即 :after
和 :before
)以减少缓冲区 div
的数量。
body {
margin: 8px;
}
.wrapper {
display: flex;
flex-wrap: wrap;
justify-content: center;
}
.container {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
flex-grow: 2.5;
}
.content {
width: 50px;
border: solid 1px red;
}
.pseudo-buffer:before, .pseudo-buffer:after {
content:" ";
display: block;
}
.wrapper.pseudo-buffer:before, .wrapper.pseudo-buffer:after {
flex-grow: 10;
}
.buffer {
flex-grow: 2.5;
}
@media (max-width: 224px) {
.wrapper {
display: block;
}
.container {
justify-content: center;
flex-grow: 0;
}
.wrapper.pseudo-buffer:before, .wrapper.pseudo-buffer:after {
display: none;
}
.container.pseudo-buffer:before, .container.pseudo-buffer:after {
flex-grow: 10;
}
}
@media (max-width: 120px) {
.wrapper {
display: flex;
}
.wrapper.pseudo-buffer:before, .wrapper.pseudo-buffer:after, .container.pseudo-buffer:before, .container.pseudo-buffer:after, .buffer {
display: none;
}
}
<div class="wrapper pseudo-buffer">
<div class="container pseudo-buffer">
<div class="content">Some Content</div>
<div class="buffer"></div>
<div class="content">Some Content</div>
</div>
<div class="buffer"></div>
<div class="container pseudo-buffer">
<div class="content">Some Content</div>
<div class="buffer"></div>
<div class="content">Some Content</div>
</div>
</div>
您也可以在不使用任何 buffer
div 的情况下执行此操作,只需根据 @media
查询断点和将宽度设置为 container
我正在使用两个 @media
查询断点,因为我认为,如果每行只有一个 content
div,那么 content
div 应该是在 container
div 内水平居中,如果您不想使用第二个 @media
查询断点,则只需将其删除并设置 min-width: 104px;
到 @media (max-width: 208px)
的 container
。你可以这样做 JSFiddle DEMO
body {
margin: 20px 0px 0px 0px;
}
.wrapper {
display: flex;
flex-wrap: wrap;
justify-content: center;
}
.content {
width: 50px;
border: solid 1px red;
}
.container {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
flex-grow: 7.5; /* Total space between 4 content divs same as 3 x 2.5 flex-grow */
}
.wrapper:before, .wrapper:after {
content: " ";
flex-grow: 10;
}
@media (max-width: 208px) {
.container {
width: 104px; /* 2 (content divs per line) x 52px (content div's width) */
flex-grow: 2.5;
}
}
@media (max-width: 104px) {
.container {
width: 52px;
flex-grow: 0; /* Set value 0 to center content divs inside the container */
}
}
<div class="wrapper">
<div class="container">
<div class="content">Some Content</div>
<div class="content">Some Content</div>
<div class="content">Some Content</div>
<div class="content">Some Content</div>
</div>
</div>
关于javascript - 如何使用 flex-box 容器在多行上保留间距模板,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25651448/
更新 对于那些不喜欢内联 CSS 并想要类的人,这里有另一个带有类和样式表的 jsFiddle。 更新结束 我想做一个产品页面。它将包含三列。第一个是图片,第二个是一些规范,第三个是“入篮”。所有列的
我创建了一个简单的测试应用程序 使用以下代码 var i : int; for (i=0; i *
我做了一个小demo http://html5.by/blogdemo/flexbox/flex-grow-shrink-basis-stackoverflow.html flex 容器中有2个 fl
我读过好几遍,要让 flex-grow 按预期工作,您通常需要设置 flex-grow:1(或 flex: 1) 在元素的父级、其父级等上,一直向上。 在学习 flexbox 时,这给我的印象是它具有
我开始学习 FLEX。我只有 flex sdk。所以我只能使用它开始学习吗?如果是这样,请建议我要通过的链接.. 但是,使用编辑器将最大限度地减少我们的工作,并自行创建代码。所以作为一个新的学习者,理
有没有办法使用 flex-direction: column 在 flex 容器中放置 flex 项有相同的高度,只使用 CSS? JSFiddle:https://jsf
我有一个 flex .swf 和一个单独的 AIR 项目,我试图通过套接字相互通信。 这两个程序连接正常,.swf 能够毫无问题地将数据发送到 AIR 应用程序。但是,我发现当 AIR 应用程序将数据
在这种情况下,我希望将 2.5 放置在 2 下方 - 但 flexbox 容器强制将其放置在同一行,而不是将其放置在 div 下方那已经是那个特定的顺序了。 我如何使用 flexbox - 将包含 2
假设您有一个带有显示 flex、flex-direction 列的 div,在本例中高度为 600。 它有三个子项,每个子项的属性 flex 等于 1。前两个子项呈现一些简单文本,第三个子项呈现 h1
男孩,这个头衔是满口的。让我解释一下我的困惑: 我有一个 flex 容器和 2 个 flex 元素。 /* CSS */ .container {
这个问题在这里已经有了答案: CSS3 Flexbox: display: box vs. flexbox vs. flex (3 个答案) 关闭 1 年前。 今天我们中的许多人都知道 displa
其用例是带有单选按钮的响应式表单。当在大 PC 屏幕上时,所有单选按钮通常都在屏幕上的一行中(就像带有 flex-direction: row 的非包装 flex 容器中的 flex 元素)。在电话上
在可访问的 flex 应用程序中,用户可以使用 TAB 键在控件中导航。 在用户激活特定链接后,flex 应用程序会在 html 页面顶部弹出,并使用 swfobject.embedSWF 加载。 它
我将我的 Flex 3 项目导入 Flex 4 并删除了 Flex 4 问题窗口中列出的所有错误和警告。 启动我的应用程序时,我在 Flex 4 中遇到以下错误。 这可能是什么原因? Error: C
我有如下标记: alot of text 我不能让黄色占据红色的 100% 高度,即使红色溢出,它也只占据窗口的 100%。如果我将红色的 display
我在 Eclispe 3.4 中安装了 flex builder 3 插件。现在许可证过期了。所以我需要在其中添加另一个许可证。但我无法更改许可证 key ,因为该选项已禁用。 因此,请任何人知道如何
这个问题在这里已经有了答案: Make flex items have equal width in a row (3 个答案) How to make Flexbox items the same
我正在尝试理解以下行。 flex :0 1 50% 现在,如果最后一个值,flex basis 是像素,上面会说该元素不允许增长,但允许缩小并且最大为 50 像素。 但是用百分比代替,有什么关系。它将
我一直致力于 flex 布局,遇到了针对 Firefox 和 IE11 的问题。 我创建了一个 codepen显示问题。 截图 Chrome(左)、Firefox(右) 描述 预期的行为是header
我正在尝试在 flex (flash builder 4) 中创建一个简单的表单。我在里面放了一个表单容器和 FormItems。例如,表单项是标准的“客户”字段,例如名字、姓氏、地址、城市、州、 z
我是一名优秀的程序员,十分优秀!