猿问

当它们的高度由它们的内容定义时,如何确保两个元素在所有屏幕宽度上具有相同的高度?

我有一个现有页面,有两个单独的元素,每个元素的高度由它们的内容设置(此处为 CodePen)。如何确保两者在所有屏幕宽度下都具有相同的高度?问题是,我不能使用 CSS flex 或 grid :-/ 相反,这两个元素不能在同一个 flex 容器或 grid 容器中。我这么说是因为已经构建了一个大页面,具有某种 HTML 结构,不允许这些元素位于相同的 flex/grid 容器中(请参见此处的示例页面)。


我愿意接受一些黑客解决方案。


如果这可能有帮助,我也对 JavaScript 持开放态度。


选项


我想到了一个 JavaScript 解决方案来读取元素 2 的高度,并将元素 1 的高度设置为该值。但是如果用户调整他的浏览器大小会发生什么——这两个元素是否保证保持相同的高度?如果用户在移动设备上并旋转显示器会发生什么——这两个元素是否保证保持相同的高度?


谢谢。


我的 CodePen 代码:


HTML


<div class='a'>Element A</div>

<div class='b'>Element B:  Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. </div>

CSS


.a {

  display: inline-block;

  background-color: yellow;

  width: 45%;

  border: 1px solid black;

}


.b {

  display: inline-block;

  background-color: red;

  width: 45%;

  border: 1px solid black;

}


慕仙森
浏览 114回答 2
2回答

慕田峪4524236

当然,使用 flexbox 会更容易:)如果您可以使用表格,那么您可以执行以下操作:/* Added */#wrapper{&nbsp;display: table;&nbsp;width: 100%;}.a {&nbsp;&nbsp;&nbsp; display: table-cell; /* Added */&nbsp; vertical-align: top; /* Added */&nbsp; /* display: inline-block; */&nbsp; background-color: yellow;&nbsp; width: 50%; /* Changed */&nbsp; border: 1px solid black;}.b {&nbsp; display: table-cell; /* Added */&nbsp; vertical-align: top; /* Added */&nbsp; /* display: inline-block; */&nbsp; background-color: red;&nbsp; width: 50%; /* Changed */&nbsp; border: 1px solid black;}<div id="wrapper">&nbsp; <div class='a'>Element A</div>&nbsp; <div class='b'>Element B:&nbsp; Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. </div><div>如果您需要不同的列,您可以添加一个空列并相应地设置不同的宽度:#wrapper{&nbsp;display: table;&nbsp;width: 100%;}.a {&nbsp;&nbsp;&nbsp; display: table-cell;&nbsp; vertical-align: top;&nbsp; background-color: yellow;&nbsp; width: 45%; /* Changed */&nbsp; border: 1px solid black;}.b {&nbsp; display: table-cell;&nbsp; vertical-align: top;&nbsp; background-color: red;&nbsp; width: 45%; /* Changed */&nbsp; border: 1px solid black;}/*added*/.gap{&nbsp; display: table-cell;&nbsp; vertical-align: top;&nbsp; width: 10%; /* which is 100 - 2* 45 */}<div id="wrapper">&nbsp; <div class='a'>Element A</div>&nbsp; <!-- ------------------------Added------------------------------ -->&nbsp; <div class='gap'></div>&nbsp; <!-- ----------------------------------------------------------- -->&nbsp; <div class='b'>Element B:&nbsp; Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. </div><div>如果您可以使用 CSS 变量(请参阅 comptability):#wrapper{&nbsp;display: table;&nbsp;width: 100%;&nbsp;--column-width: 49%; /* so you can set any value between 0 & 50% and the gap will fill the rest */&nbsp;--number-of-column: 2; /* minimun 2 */&nbsp;--number-of-gap: calc(var(--number-of-column) - 1);&nbsp;--column-gap: calc((100% - var(--column-width) * var(--number-of-column)) / var(--number-of-gap));}.columns{&nbsp; display: table-cell;&nbsp; vertical-align: top;}.column-content{&nbsp; width: var(--column-width);&nbsp; border: 1px solid black;}.column-gap{&nbsp; width: var(--column-gap, 0%); /* If we set just one column, --column-gap is undefined (because it divises by 0), so we need a default value, which is 0% because in this case of only one column, we have no gap column */}.a {&nbsp; background-color: yellow;}.b {&nbsp; background-color: red;}<div id="wrapper">&nbsp; <div class='columns column-content a'>Element A</div>&nbsp; <div class='columns column-gap'></div>&nbsp; <div class='columns column-content b'>Element B:&nbsp; Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. </div><div>

慕村225694

使用 Flex 怎么样?HTML:<div class="row-test"><div class='a'>Element A</div><div class='b'>Element B:&nbsp; Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. Here is more text. </div></div>CSS:.a {&nbsp; display: inline-block;&nbsp; background-color: yellow;&nbsp; width: 45%;&nbsp; border: 1px solid black;&nbsp; flex: 1;}.b {&nbsp; display: inline-block;&nbsp; background-color: red;&nbsp; width: 45%;&nbsp; border: 1px solid black;&nbsp; flex: 1;}.row-test {&nbsp; display: flex}很棒的弹性指南: https ://css-tricks.com/snippets/css/a-guide-to-flexbox/弹性支持: https ://caniuse.com/#feat=flexbox
随时随地看视频慕课网APP

相关分类

JavaScript
我要回答