0

0

使用Bulma构建固定页眉页脚与可滚动内容区域的布局

碧海醫心

碧海醫心

发布时间:2025-12-09 16:09:57

|

261人浏览过

|

来源于php中文网

原创

使用Bulma构建固定页眉页脚与可滚动内容区域的布局

本文详细阐述如何在bulma框架下实现固定在页面顶部和底部的导航栏与页脚,同时确保中间内容区域可独立滚动。通过利用bulma提供的`is-fixed-top`和`is-fixed-bottom`类,并配合`has-navbar-fixed-top`和`has-navbar-fixed-bottom`等辅助类,可以有效解决传统`hero`组件在内容过长时页脚被推出视口的问题,从而创建出具有良好用户体验的响应式布局

在现代网页设计中,保持页面的导航栏(页眉)和页脚始终可见,同时允许主体内容区域独立滚动,是一种常见的用户体验需求。这确保了用户无论内容多长,都能方便地访问导航和版权信息。然而,在使用像Bulma这样的CSS框架时,如果不了解其特定机制,可能会遇到一些挑战,例如当内容区域过长时,页脚被推出视口的问题。

传统hero组件的局限性

许多开发者尝试使用Bulma的hero组件配合is-fullheight类来构建全屏布局,并希望其子元素hero-head、hero-body和hero-footer能够实现固定页眉页脚和可滚动内容的效果。然而,hero组件的is-fullheight特性旨在使其占据整个视口高度,而hero-body会根据内容扩展。当hero-body的内容超出视口高度时,hero-footer就会被推到视口之外,导致其无法固定显示。

要解决这个问题,我们需要采用Bulma提供的固定定位(Fixed Positioning)机制,而不是依赖hero组件来管理整个页面的布局。

实现固定页眉(导航栏)

Bulma为导航栏提供了方便的固定定位类。通过将is-fixed-top类应用于navbar组件,可以使其始终固定在视口顶部。

步骤:

  1. 添加固定导航栏类: 在你的

  2. 处理内容重叠问题: 当导航栏固定在顶部时,它会脱离文档流,导致其下方的页面内容向上移动并可能被导航栏遮挡。为了解决这个问题,Bulma提供了has-navbar-fixed-top类,该类会给html>或

    元素添加适当的顶部内边距(padding),以确保内容不会被遮挡。
    
    
    
        
        
        
        

    我的可滚动内容

    ...

实现固定页脚

与固定页眉类似,Bulma也提供了is-fixed-bottom类来固定元素到视口底部。通常,我们会将一个footer元素(或一个样式为页脚的navbar)固定在底部。

故事AI绘图神器
故事AI绘图神器

文本生成图文视频的AI工具,无需配音,无需剪辑,快速成片,角色固定。

下载

步骤:

  1. 添加固定页脚类: 在你的

    标签中,添加is-fixed-bottom类。

  2. 处理内容重叠问题: 同样地,固定页脚也会脱离文档流。Bulma提供了has-navbar-fixed-bottom类来为或

    元素添加底部内边距,以防止主要内容被页脚遮挡。
    
    
    
        
    
    

    请注意,如果同时使用固定顶部导航栏和固定底部页脚,你需要同时添加has-navbar-fixed-top和has-navbar-fixed-bottom类。

整合与可滚动内容区域

通过上述步骤,你的导航栏和页脚将始终固定在视口顶部和底部。页面的主要内容区域(例如一个

)将自动占据两者之间的空间。当这个主要内容区域的内容超出其可用高度时,浏览器会自动为其生成滚动条,实现你所需的可滚动效果。

完整示例结构:




    
    
    Bulma固定页眉页脚与可滚动内容
    
    



    
    

    
    

欢迎来到我的网站!

这是一个带有固定页眉和页脚的页面。

这里是页面的主要内容。当这些内容足够长时,您会发现只有这个区域可以滚动,而顶部的导航栏和底部的页脚始终保持可见。 这种布局对于需要展示大量信息,同时又希望用户能够随时访问重要导航链接和版权信息的网站非常有用。

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.

Curabitur pretium tincidunt lacus, ac venenatis enim semper sit amet. Proin sit amet purus eu velit lacinia facilisis. Mauris sed odio in massa posuere tristique. Donec nec metus id felis ullamcorper efficitur. Sed sit amet nisl id enim tincidunt ultrices. Nulla facilisi. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Vivamus in arcu sit amet purus.

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.

Curabitur pretium tincidunt lacus, ac venenatis enim semper sit amet. Proin sit amet purus eu velit lacinia facilisis. Mauris sed odio in massa posuere tristique. Donec nec metus id felis ullamcorper efficitur. Sed sit amet nisl id enim tincidunt ultrices. Nulla facilisi. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Vivamus in arcu sit amet purus.

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.

Curabitur pretium tincidunt lacus, ac venenatis enim semper sit amet. Proin sit amet purus eu velit lacinia facilisis. Mauris sed odio in massa posuere tristique. Donec nec metus id felis ullamcorper efficitur. Sed sit amet nisl id enim tincidunt ultrices. Nulla facilisi. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Vivamus in arcu sit amet purus.

Bulma固定页脚示例. 版权所有 © 2023.

注意事项与总结

  1. Bulma版本兼容性: 确保你使用的Bulma版本支持is-fixed-top、is-fixed-bottom以及对应的has-navbar-fixed-top和has-navbar-fixed-bottom类。这些是Bulma的核心功能,通常在所有现代版本中都可用。
  2. 自定义样式: 如果Bulma提供的默认间距不完全符合你的设计,你可以通过自定义CSS覆盖html或body上的padding-top和padding-bottom值。例如:
    html.has-navbar-fixed-top {
        padding-top: 52px; /* 根据你的导航栏实际高度调整 */
    }
    html.has-navbar-fixed-bottom {
        padding-bottom: 52px; /* 根据你的页脚实际高度调整 */
    }
  3. Z-index: 固定定位的元素默认具有较高的堆叠顺序。如果遇到其他元素遮挡固定导航栏或页脚的问题,可能需要手动调整它们的z-index值。
  4. 响应式设计 确保在不同屏幕尺寸下,固定元素和可滚动内容的布局依然表现良好。Bulma的navbar组件本身是响应式的,但你可能需要对内容区域进行额外的媒体查询调整。

通过采用Bulma的固定定位类,我们可以轻松实现具有固定页眉、页脚和可滚动内容区域的复杂布局,从而提升用户界面的可用性和专业性。这种方法比尝试强制hero-body滚动更为健壮和符合框架设计哲学。

使用Bulma构建固定页眉页脚与可滚动内容区域的布局使用Bulma构建固定页眉页脚与可滚动内容区域的布局

相关专题

更多
css
css

css是层叠样式表,用来表现HTML或XML等文件样式的计算机语言,不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

524

2023.06.15

css居中
css居中

css居中:1、通过“margin: 0 auto; text-align: center”实现水平居中;2、通过“display:flex”实现水平居中;3、通过“display:table-cell”和“margin-left”实现居中。本专题为大家提供css居中的相关的文章、下载、课程内容,供大家免费下载体验。

265

2023.07.27

css如何插入图片
css如何插入图片

cssCSS是层叠样式表(Cascading Style Sheets)的缩写。它是一种用于描述网页或应用程序外观和样式的标记语言。CSS可以控制网页的字体、颜色、布局、大小、背景、边框等方面,使得网页的外观更加美观和易于阅读。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

758

2023.07.28

css超出显示...
css超出显示...

在CSS中,当文本内容超出容器的宽度或高度时,可以使用省略号来表示被隐藏的文本内容。本专题为大家提供css超出显示...的相关文章,相关教程,供大家免费体验。

539

2023.08.01

css字体颜色
css字体颜色

CSS中,字体颜色可以通过属性color来设置,用于控制文本的前景色,字体颜色在网页设计中起到很重要的作用,具有以下表现作用:1、提升可读性;2、强调重点信息;3、营造氛围和美感;4、用于呈现品牌标识或与品牌形象相符的风格。

761

2023.08.10

什么是css
什么是css

CSS是层叠样式表(Cascading Style Sheets)的缩写,是一种用于描述网页(或其他基于 XML 的文档)样式与布局的标记语言,CSS的作用和意义如下:1、分离样式和内容;2、页面加载速度优化;3、实现响应式设计;4、确保整个网站的风格和样式保持统一。

605

2023.08.10

css三角形怎么写
css三角形怎么写

CSS可以通过多种方式实现三角形形状,本专题为大家提供css三角形怎么写的相关教程,大家可以免费体验。

560

2023.08.21

css设置文字颜色
css设置文字颜色

CSS(层叠样式表)可以用于设置文字颜色,这样做有以下好处和优势:1、增加网页的可视化效果;2、突出显示某些重要的信息或关键字;3、增强品牌识别度;4、提高网页的可访问性;5、引起不同的情感共鸣。

397

2023.08.22

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

19

2026.01.20

热门下载

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

精品课程

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

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

CSS教程
CSS教程

共754课时 | 21.4万人学习

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

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