- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
抱歉标题不好,我不确定如何更好地解释我的问题。请随时将其更改为更好的内容。
此外,我是 flexboxes 的新手,这使得我更难找到我的问题。所以我设置了一个 JSFiddle显示我的问题。
/* Layout */
#pagecontentwrapper {
display: -ms-flexbox;
display: -webkit-flex;
display: flex;
-webkit-flex-direction: column;
-ms-flex-direction: column;
flex-direction: column;
min-height: 100%;
padding: 25px;
}
/* Inhalte */
#flexcontainer {
display: -webkit-box;
display: -ms-flexbox;
display: -webkit-flex;
display: flex;
-webkit-box-flex: 1;
-webkit-flex: 1;
-ms-flex: 1;
flex: 1;
}
/* Flex */
.rowParent,
.columnParent {
display: -webkit-box;
display: -ms-flexbox;
display: -webkit-flex;
display: flex;
-webkit-box-direction: normal;
-webkit-box-orient: horizontal;
-webkit-flex-direction: row;
-ms-flex-direction: row;
flex-direction: row;
-webkit-flex-wrap: nowrap;
-ms-flex-wrap: nowrap;
flex-wrap: nowrap;
-webkit-box-pack: start;
-webkit-justify-content: flex-start;
-ms-flex-pack: start;
justify-content: flex-start;
}
.columnParent {
-webkit-box-orient: vertical;
-webkit-flex-direction: column;
-ms-flex-direction: column;
flex-direction: column;
}
.flexMother {
-webkit-box-flex: 1;
-webkit-flex: 1;
-ms-flex: 1;
flex: 1;
-webkit-align-self: auto;
-ms-flex-item-align: auto;
align-self: auto;
}
.flexChild {
-webkit-box-flex: 1;
-webkit-flex: 1;
-ms-flex: 1;
flex: 1;
-webkit-align-self: auto;
-ms-flex-item-align: auto;
align-self: auto;
display: flex;
}
.topflex {
-webkit-align-self: flex-start;
-ms-flex-item-align: flex-start;
align-self: flex-start;
width: 100%;
}
.bottomflex {
-webkit-align-self: flex-end;
-ms-flex-item-align: flex-end;
align-self: flex-end;
}
#aktuelles {
border: 1px solid #004985;
}
#besucher,
#raumplan,
#media,
#topnews,
#technik {
border: 1px solid #a0a0a0;
}
#besucher,
#raumplan,
#topnews {
margin-bottom: 35px;
}
#aktuelles {
margin-right: 25px;
}
#besucher,
#raumplan,
#media {
margin-right: 12px;
}
#topnews,
#technik {
margin-left: 13px;
}
article.news_front {
padding: 20px;
}
article.news_front:last-of-type {
margin-bottom: 0;
}
article.news_front:last-of-type section {
border-bottom: none;
}
article.news_front section {
border-bottom: 1px solid #004985;
}
article.news_front section p:first-of-type {
display: inline;
}
article.besucher_front section {
margin-left: 45px;
}
.topflex {
background-color: red;
}
.bottomflex {
background-color: grey;
}
<div id="pagecontentwrapper">
<div id="flexcontainer" class="flexMother rowParent">
<div id="aktuelles" class="flexChild">
<div class="topflex">
<h1 class="frontpage">Aktuelles</h1>
<article class="news_front">
<section><span class="posttime">13. 11. 2014, 16:09 Uhr</span>
<p>Lorem ipsum...</p>
</section>
</article>
<article class="news_front">
<section><span class="posttime">13. 11. 2014, 12:00 Uhr</span>
<p>Lorem ipsum...</p>
</section>
</article>
<article class="news_front">
<section><span class="posttime">13. 11. 2014, 8:15 Uhr</span>
<p>Lorem ipsum...</p>
</section>
</article>
</div>
<div class="bottomflex">Historie</div>
</div>
<div id="rechtehaelfte" class="flexChild rowParent">
<div id="mittlerespalte" class="flexChild columnParent">
<div id="besucher" class="flexChild">
<div class="topflex">
<h1 class="frontpage">Besucher</h1>
<article class="besucher_front">
<p>Für heute sind keine Besucher eingetragen.</p>
</article>
</div>
<div class="bottomflex"> </div>
</div>
<div id="raumplan" class="flexChild">
<div class="topflex">
<h1 class="frontpage">Raumplan</h1>
<article class="besucher_front">
<p>Für heute ist keine Raumbelegung eingetragen.</p>
</article>
</div>
<div class="bottomflex"> </div>
</div>
<div id="media" class="flexChild">
<div class="topflex">
<h1 class="frontpage">Media</h1>
<p>image here</p>
</div>
</div>
</div>
<div id="rechtespalte" class="flexChild columnParent">
<div id="topnews" class="flexChild">
<div class="topflex">
<h1 class="frontpage">Top-News</h1>
<article class="topnews_front">
<section>
<p>Lorem ipsum...</p>
</section>
</article>
</div>
<div class="bottomflex" id="topnews_historie">Historie</div>
</div>
<div id="technik" class="flexChild">
<div class="topflex">
<h1 class="frontpage">Technik</h1>
<article class="news_front">
<section><span class="posttime">3. 1. 2015, 21:36 Uhr</span>
<p>Lorem ipsum...</p>
</section>
</article>
</div>
<div class="bottomflex" id="technik_historie">Historie</div>
</div>
</div>
</div>
</div>
</div>
我想要实现的是,.bottomflex-container
位于 .topflex-container
之下,而不是像它发生的那样紧挨着它。
我可以暂时实现那种效果,当我设置
flex-direction: column;
到 .flexChild
。但后来我失去了行为,我的 .bottomflex-container
位于周围框的底部,我明白为什么会这样。
我不确定我是否正在尝试做一些不可能的事情并且需要做不同的事情,或者我是否只是遗漏了一些代码行。
最佳答案
flex 元素一个接一个地显示,因为默认情况下,flex-wrap
设置为nowrap
,因此 children 被迫进入单例。
为了让 flex 元素分成多行,你可以使用
.flexChild {
flex-wrap: wrap;
}
/* Layout */
#pagecontentwrapper {
display: -ms-flexbox;
display: -webkit-flex;
display: flex;
-webkit-flex-direction: column;
-ms-flex-direction: column;
flex-direction: column;
min-height: 100%;
padding: 25px;
}
/* Inhalte */
#flexcontainer {
display: -webkit-box;
display: -ms-flexbox;
display: -webkit-flex;
display: flex;
-webkit-box-flex: 1;
-webkit-flex: 1;
-ms-flex: 1;
flex: 1;
}
/* Flex */
.rowParent,
.columnParent {
display: -webkit-box;
display: -ms-flexbox;
display: -webkit-flex;
display: flex;
-webkit-box-direction: normal;
-webkit-box-orient: horizontal;
-webkit-flex-direction: row;
-ms-flex-direction: row;
flex-direction: row;
-webkit-flex-wrap: nowrap;
-ms-flex-wrap: nowrap;
flex-wrap: nowrap;
-webkit-box-pack: start;
-webkit-justify-content: flex-start;
-ms-flex-pack: start;
justify-content: flex-start;
}
.columnParent {
-webkit-box-orient: vertical;
-webkit-flex-direction: column;
-ms-flex-direction: column;
flex-direction: column;
}
.flexMother {
-webkit-box-flex: 1;
-webkit-flex: 1;
-ms-flex: 1;
flex: 1;
-webkit-align-self: auto;
-ms-flex-item-align: auto;
align-self: auto;
}
.flexChild {
-webkit-box-flex: 1;
-webkit-flex: 1;
-ms-flex: 1;
flex: 1;
-webkit-align-self: auto;
-ms-flex-item-align: auto;
align-self: auto;
display: flex;
flex-wrap: wrap;
}
.topflex {
-webkit-align-self: flex-start;
-ms-flex-item-align: flex-start;
align-self: flex-start;
width: 100%;
}
.bottomflex {
-webkit-align-self: flex-end;
-ms-flex-item-align: flex-end;
align-self: flex-end;
}
#aktuelles {
border: 1px solid #004985;
}
#besucher,
#raumplan,
#media,
#topnews,
#technik {
border: 1px solid #a0a0a0;
}
#besucher,
#raumplan,
#topnews {
margin-bottom: 35px;
}
#aktuelles {
margin-right: 25px;
}
#besucher,
#raumplan,
#media {
margin-right: 12px;
}
#topnews,
#technik {
margin-left: 13px;
}
article.news_front {
padding: 20px;
}
article.news_front:last-of-type {
margin-bottom: 0;
}
article.news_front:last-of-type section {
border-bottom: none;
}
article.news_front section {
border-bottom: 1px solid #004985;
}
article.news_front section p:first-of-type {
display: inline;
}
article.besucher_front section {
margin-left: 45px;
}
.topflex {
background-color: red;
}
.bottomflex {
background-color: grey;
}
<div id="pagecontentwrapper">
<div id="flexcontainer" class="flexMother rowParent">
<div id="aktuelles" class="flexChild">
<div class="topflex">
<h1 class="frontpage">Aktuelles</h1>
<article class="news_front">
<section><span class="posttime">13. 11. 2014, 16:09 Uhr</span>
<p>Lorem ipsum...</p>
</section>
</article>
<article class="news_front">
<section><span class="posttime">13. 11. 2014, 12:00 Uhr</span>
<p>Lorem ipsum...</p>
</section>
</article>
<article class="news_front">
<section><span class="posttime">13. 11. 2014, 8:15 Uhr</span>
<p>Lorem ipsum...</p>
</section>
</article>
</div>
<div class="bottomflex">Historie</div>
</div>
<div id="rechtehaelfte" class="flexChild rowParent">
<div id="mittlerespalte" class="flexChild columnParent">
<div id="besucher" class="flexChild">
<div class="topflex">
<h1 class="frontpage">Besucher</h1>
<article class="besucher_front">
<p>Für heute sind keine Besucher eingetragen.</p>
</article>
</div>
<div class="bottomflex"> </div>
</div>
<div id="raumplan" class="flexChild">
<div class="topflex">
<h1 class="frontpage">Raumplan</h1>
<article class="besucher_front">
<p>Für heute ist keine Raumbelegung eingetragen.</p>
</article>
</div>
<div class="bottomflex"> </div>
</div>
<div id="media" class="flexChild">
<div class="topflex">
<h1 class="frontpage">Media</h1>
<p>image here</p>
</div>
</div>
</div>
<div id="rechtespalte" class="flexChild columnParent">
<div id="topnews" class="flexChild">
<div class="topflex">
<h1 class="frontpage">Top-News</h1>
<article class="topnews_front">
<section>
<p>Lorem ipsum...</p>
</section>
</article>
</div>
<div class="bottomflex" id="topnews_historie">Historie</div>
</div>
<div id="technik" class="flexChild">
<div class="topflex">
<h1 class="frontpage">Technik</h1>
<article class="news_front">
<section><span class="posttime">3. 1. 2015, 21:36 Uhr</span>
<p>Lorem ipsum...</p>
</section>
</article>
</div>
<div class="bottomflex" id="technik_historie">Historie</div>
</div>
</div>
</div>
</div>
</div>
关于css - Flexbox 彼此相邻对齐,尽管宽度设置为 100%,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27913156/
我想在数组中找到连接(相邻)的元素。 例如,在数组中: [1,2,3,4,5] 要访问所有 2 个连通元素,输出将为: 1,2 2,3 3,4 4,5 要访问所有 3 个连通元素,输出将为 1,2,3
我有三个 Sprite ,彼此堆叠在一起。 我修改了他们的 transform.matrix 以给出他们一致增长的外观。 但是,根据比例因子,瓷砖之间有时会出现小裂缝。 cracks between
我正在阅读有关 Margin Collapsing 的文章,我遇到了这个:margin Adjacent siblings The margins of adjacent siblings are c
float div 的框阴影被其右侧的邻居截断,但左侧未截断。 我玩过 z-index 和 overflow: visible,但没有用。 HTML: CSS: .doc-page {
我有多个元素说卡片。这些卡片需要水平堆叠并且高度需要相同。这正在发生在我身上。 每张卡片都有图像、文本和按钮。每张卡片的图像和文本应采用任何卡片中的最大高度,以便它们正确对齐。这不会发生在我身上。 如
我有这个 GUI 我使用了 GridBagLayout,但我不知道为什么 Plain Bread 复选框与其相应的标签之间有很大的间距。 而且,我尝试仅增加按钮沿 x 轴的间距,但尽管重置了插图,但沿
在过去,我已经为自定义元素符号使用了数百次列表项背景图像,但不知何故从未遇到过这个问题。 基本上,我有一个 IMG float 在无序列表的左侧。元素符号背景图像设置在每个 LI 的左上角。但是, f
我正在使用 Bootstrap 框架并使用 2 列网格。 html 内容有标题、链接、副标题和文本。这增加了该列的高度。我希望它旁边的列与其高度匹配(以便图像显示)没有设置高度图像不显
我有一个 php 代码可以生成数百个 和 标签。我的问题如下,我有以下内容: X X 我想要第二个的边框颜色更重要,以便共享边框显示为灰色而不是黑色。我可以在第二个 td 中使用重要性或继承标签吗?
Place holder for Radio1 Place holder for Radio2 在此,我只想要 与相应的单选按钮相关联是可见的,但是...... * { visibilit
我正在尝试在 html 中实现以下布局。更大的 div 1。然后是它旁边的另一个 div,顶部有一个边距。如果我给 float: left 给第一个 div,给第二个 div margin-top 也
假设我有 2 个名为 IN 和 MASK 的二进制输入。实际字段大小可能是 32 到 256 位,具体取决于用于完成任务的指令集。两个输入都会改变每次调用。 Inputs: IN = ...110
我想知道是否有一种简洁/一行的方法来执行以下操作: pack :: [a] -> [(a, a)] pack [] = [] pack [_] = [] pack (x:y:xs
下面的代码分为两部分,一部分处理头部的管理,另一部分处理“主体”,当我执行代码时引发下面的异常,我该如何解决该错误?我不知道下面的错误是什么原因造成的,错误是在react的解析上 错误: Line
http://imgur.com/a/DA5i4 在上面的两张图片中你可以看到我有一个主容器,里面装满了 3 个较小的 div,一个大的在中间,两个瘦的在两边,但是右边直到中间的 div 下面才开始。
正如我在标题中解释的所有内容,然后我将只为你们提供我现在拥有的代码,我一直在努力实现我想要的东西很长时间但没有运气......它表现得像响应式的,但即使调整大小我也想将其保持在原位...截图
我编写了一个 jquery 插件,它使用 Flot 将 HTML 表格转换为图表。 HTML 是从 XSLT 生成的,在 XSLT 中我有以下代码来调用我的插件。此代码尝试在 blah1 和 blah
我正在尝试实现这样的布局。 aaa xxxxxx oooo aaa xxxxxx oooo xxxxxx xxxxxx bbb xxxxxx cccc bbb xxxxxx cc
在包含网格的 2 个 div 上使用内联 css 显示不起作用 最佳答案 为您的 div 指定宽度并根据您的要求使用“float: left”或“right”。不要对 div 使用“内联” 例如 CS
我将 MVC 项目中的一些代码返回到网页。我无法用撇号解决问题,当我的电话看起来像这样时,我如何忽略它 document.getElementById('some').insertAdjacentHT
我是一名优秀的程序员,十分优秀!