0

0

Bootstrap 4:响应式列高度自适应内容

心靈之曲

心靈之曲

发布时间:2025-10-19 09:08:19

|

977人浏览过

|

来源于php中文网

原创

bootstrap 4:响应式列高度自适应内容

本文介绍了如何在使用 Bootstrap 4 构建响应式布局时,使两列在移动设备上折叠成一列后,其高度能够根据内容自适应。核心在于利用 `@media` 查询,在特定屏幕尺寸下,强制将 `row` 元素的 `display` 属性设置为 `block!important`,从而解决列高度平均分配的问题,确保内容较少的列也能正确显示。

在使用 Bootstrap 4 创建响应式布局时,经常会遇到需要在不同屏幕尺寸下调整列的排列方式。一种常见的需求是在桌面端并排显示两列,而在移动端将它们折叠成一列。然而,当内容较少时,折叠后的列可能会出现高度不正确的问题,导致视觉效果不佳。本文将详细介绍如何解决这个问题,确保列的高度始终根据内容自适应。

问题描述

假设我们有一个包含头部、内容区域和底部的布局,内容区域包含两列,并且这两列需要支持滚动。在桌面端,我们希望这两列并排显示,并且可以独立滚动。在移动端,我们希望这两列折叠成一列,垂直排列。

以下是一个基本的 HTML 结构:




    
    
    Bootstrap 4 Responsive Columns
    
    


    
Header
Hello
Hello
Hello
Hello
Hello
Hello
Hello
Hello
Hello
Hello
Hello
Hello
Hello
Hello
Hello
Hello
Hello
Hello
Hello
Hello
Hello
World
World
World
World
World
World
World
World
World
World
World
World
World
World
World
World
World
World
World
World
World
Footer

在上述代码中,我们使用了 Bootstrap 4 的类来创建布局。container-fluid 类用于创建一个全宽的容器,d-flex 和 flex-column 类用于创建一个垂直的 flex 容器,vh-100 类用于设置容器的高度为视口高度。row 类用于创建行,col-6 类用于创建占据一半宽度的列,mh-100 类用于设置列的最小高度为 100%,overflow-auto 类用于在内容超出列的高度时显示滚动条。flex-grow-1 使内容区域可以占据剩余的空间。

当内容较少,没有滚动条时,这两列可能会平均分配高度,导致显示不正确。

解决方案

为了解决这个问题,我们可以使用 @media 查询,在移动端强制将 row 元素的 display 属性设置为 block!important。这样可以覆盖 Bootstrap 默认的 flex 布局,使列的高度根据内容自适应。

ISite企业建站系统1.2.3
ISite企业建站系统1.2.3

ISite企业建站系统是为懂点网站建设和HTML技术的人员(例如企业建站人员)而开发的一套专门用于企业建站的开源免费程序。本系统采用了全新的栏目维护模式,内容添加过程中,前后台菜单是一样的,需要维护前台某个栏目的内容,只需要进后台相应栏目即可,一般的企业人员只需要查看简易的说明就可以上手维护网站内容。通过自由度极高的模板系统,可以适应大多数情况的界面需求,后台带有标签生成器,建站只需要构架好HTM

下载

以下是修改后的 CSS 代码:

html,
body {
  height: 100%;
}

@media (max-width: 768px) {
  .row.flex-grow-1 {
    display: block !important;
  }
}

在这个 CSS 代码中,我们使用了 @media (max-width: 768px) 查询,表示当屏幕宽度小于等于 768 像素时,应用以下样式。我们将 row 元素的 display 属性设置为 block !important,强制覆盖 Bootstrap 默认的 flex 布局。

以下是修改后的 HTML 代码:




    
    
    Bootstrap 4 Responsive Columns
    
    


    
Header
Hello
World
Footer

在这个 HTML 代码中,我们将 col-6 类修改为 col-12 类,使列在移动端占据全部宽度。同时,我们将 overflow-auto 类修改为 overflow-visible 类,允许内容超出列的高度。

总结

通过使用 @media 查询,我们可以轻松地解决 Bootstrap 4 响应式布局中列高度自适应的问题。这种方法简单有效,可以确保列的高度始终根据内容自适应,从而提高用户体验。

注意事项:

  • 使用 !important 可能会影响 CSS 的优先级,因此应该谨慎使用。
  • 根据实际需求调整 @media 查询的屏幕宽度。
  • 确保 CSS 代码的优先级高于 Bootstrap 默认的样式。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
overflow什么意思
overflow什么意思

overflow是一个用于控制元素溢出内容的属性,当元素的内容超出其指定的尺寸时,overflow属性可以决定如何处理这些溢出的内容。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1759

2024.08.15

flex教程
flex教程

php中文网为大家带来了flex教程合集,Flex是采用Flex布局的元素,称为Flex容器(flex container),简称"容器",它的所有子元素自动成为容器成员,有三个核心概念: flex项,需要布局的元素;flex容器,其包含flex项;排列方向,这决定了flex项的布局方向。php中文网还为大家带来flex的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

359

2023.06.14

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

0

2026.01.30

c++ 字符串格式化
c++ 字符串格式化

本专题整合了c++字符串格式化用法、输出技巧、实践等等内容,阅读专题下面的文章了解更多详细内容。

0

2026.01.30

java 字符串格式化
java 字符串格式化

本专题整合了java如何进行字符串格式化相关教程、使用解析、方法详解等等内容。阅读专题下面的文章了解更多详细教程。

0

2026.01.30

python 字符串格式化
python 字符串格式化

本专题整合了python字符串格式化教程、实践、方法、进阶等等相关内容,阅读专题下面的文章了解更多详细操作。

0

2026.01.30

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

19

2026.01.29

java配置环境变量教程合集
java配置环境变量教程合集

本专题整合了java配置环境变量设置、步骤、安装jdk、避免冲突等等相关内容,阅读专题下面的文章了解更多详细操作。

16

2026.01.29

java成品学习网站推荐大全
java成品学习网站推荐大全

本专题整合了java成品网站、在线成品网站源码、源码入口等等相关内容,阅读专题下面的文章了解更多详细推荐内容。

17

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

CSS教程
CSS教程

共754课时 | 25.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号