搜索
首页web前端css教程如何使用 CSS Flex 实现左右布局的同高度边框?

如何使用 CSS Flex 实现左右布局的同高度边框?

CSS Flex 布局下实现左右两栏等高边框的技巧

在使用 CSS Flex 布局时,常常需要将页面分割成上下两部分,下半部分再细分为左右两栏。如果左右两栏高度不固定,如何确保分割它们的边框能够自动延伸至最高的高度呢?本文提供两种方案解决这个问题。

场景: 页面分为上下两部分,下半部分采用 Flex 布局,左右两栏高度不确定,需要在两栏之间添加一个等高的边框。

方案一:基于现有结构的 jQuery 调整

如果无法修改HTML结构,可以采用这种方法。 首先,为右侧元素(假设为 .rht)设置 height: min-content;,使其高度根据内容自适应。然后,使用 jQuery 获取 .rht 的高度,并将其应用于左侧元素(假设为 .lft)的子元素:

let h = $(".rht").height()   'px';
$(".lft div").css({ height: h });

这种方法依赖于 JavaScript,需要在页面加载完成后执行。

方案二:调整 HTML 结构及 CSS 样式

这种方法更简洁高效,无需 JavaScript。通过调整 HTML 结构和 CSS 样式,可以更优雅地实现等高边框。

改进后的 HTML 结构:

<div class="wrapper">
  <div class="top">顶部内容</div>  <!-- 顶部区域 -->
  <div class="content">  <!-- Flex 布局容器 -->
    <div class="lft">
      <div>左侧内容</div>
    </div>
    <div class="rht">
      <div>右侧内容</div>
    </div>
  </div>
</div>

对应的 CSS 样式:

* {
  padding: 0;
  border: 0;
  margin: 0;
  box-sizing: border-box; /*  建议添加,避免边框影响元素尺寸计算 */
}

.wrapper {
  height: 100vh; /* 占据整个视口高度 */
  display: flex;
  flex-direction: column; /*  垂直方向布局 */
}

.top {
  height: 100px;
  background: #e3e3e3;
}

.content {
  display: flex;
  flex: 1; /*  占据剩余空间 */
  min-height: 0; /*  防止最小高度影响布局 */
}

.lft {
  flex: 1; /*  占据剩余空间 */
}

.rht {
  width: 600px;
  border-left: 1px solid red;
  min-height: 0; /*  防止最小高度影响布局 */
}

在这个方案中:

  • .wrapper 使用 flex-direction: column; 实现垂直布局。
  • .content 使用 flex: 1; 占据剩余空间,确保其高度可以自适应。
  • .lft.rht 都使用 min-height: 0; 来防止最小高度限制其高度。
  • 分割线直接在 .rht 上设置 border-left

方案二通过纯 CSS 实现,性能更好,也更易于维护。 建议优先采用方案二。

以上是如何使用 CSS Flex 实现左右布局的同高度边框?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
Draggin&#039;和droppin&#039;在反应中Draggin&#039;和droppin&#039;在反应中Apr 17, 2025 am 11:52 AM

React生态系统为我们提供了许多库,所有库都集中在拖放的相互作用上。我们有反应,反应,可爱dnd,

快速软件快速软件Apr 17, 2025 am 11:49 AM

最近有一些关于快速软件的完美互连的事情。

带有背景折叠的嵌套梯度带有背景折叠的嵌套梯度Apr 17, 2025 am 11:47 AM

我可以说我经常使用背景折叠。 IT Wager IT几乎从未在日常CSS工作中使用。但是在斯特凡·朱迪斯(Stefan Judis)的帖子中,我想起了它,

使用React Hooks使用requestAnimationFrame使用React Hooks使用requestAnimationFrameApr 17, 2025 am 11:46 AM

使用RequestAnimationFrame进行动画化应该很容易,但是如果您还没有彻底阅读React的文档,那么您可能会遇到一些事情

需要滚动到页面顶部吗?需要滚动到页面顶部吗?Apr 17, 2025 am 11:45 AM

向用户提供此链接的最简单方法是针对元素上的ID的链接。如此...

最好的(GraphQl)API是您编写的API最好的(GraphQl)API是您编写的APIApr 17, 2025 am 11:36 AM

听着,我不是GraphQL专家,但我确实喜欢与之合作。作为前端开发人员,它向我曝光数据的方式非常酷。它就像一个菜单

在保留边框半径的同时,扩展盒子的各种方法在保留边框半径的同时,扩展盒子的各种方法Apr 17, 2025 am 11:19 AM

我最近注意到Codepen的一个有趣的更改:在悬停在主页上的笔时,有一个矩形,圆角在后面扩展。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 个月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
1 个月前By尊渡假赌尊渡假赌尊渡假赌
威尔R.E.P.O.有交叉游戏吗?
1 个月前By尊渡假赌尊渡假赌尊渡假赌

热工具

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具

Dreamweaver Mac版

Dreamweaver Mac版

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)