Bootstrap 5 全屏模态框需将 modal-fullscreen 类加在 modal-dialog 上,并清除其 max-width 和 margin;配合 100dvh 高度、modal-body 滚动控制及正确 JS 初始化时机,才能实现真正全屏效果。
modal-fullscreen 类直接生效但有断点限制bootstrap 5 内置了全屏模态框支持,不是靠自己写 css 覆盖,而是用 modal-fullscreen 这个类。但它默认只在特定视口宽度下触发——比如 modal-fullscreen-md-down 表示「中屏及以下才全屏」,modal-fullscreen(无后缀)则从最小屏开始就全屏。
modal-fullscreen 却没删掉 modal-dialog 默认的 max-width 和 margin,导致视觉上还是居中窄框div.modal > div.modal-dialog > div.modal-content,且 modal-fullscreen 加在 modal-dialog 上,不是 modal
modal-fullscreen;若只想手机/平板全屏、桌面恢复常规尺寸,选带断点的变体,如 modal-fullscreen-sm-down
modal-dialog 的 max-width 和 margin
内置类不够用时(比如要兼容 Bootstrap 4,或需要精确控制滚动行为),就得手动干预样式。核心是干掉 modal-dialog 的约束性声明,否则即使设了 width: 100% 也会被 max-width 截断。
.modal-dialog { width: 100%; max-width: none; margin: 0; }
height: 100vh 到 .modal-content 或 .modal-body,否则内容区不会撑满视口高度vh 单位有滚动缩放 bug,用 100dvh 更稳(但注意兼容性,dvh 是 2023 年后才普及)全屏后,用户常遇到内容被截、无法滚动、或者整个页面跟着动。这不是模态框没写对,而是 body 的 overflow 没处理好,或者子容器没设 overflow-y: auto。
body 加 overflow: hidden,但仅限于模态框打开时;关闭后会恢复——这点基本可靠.modal-body 没设固定高度 + overflow-y: auto,长内容就会把整个模态框撑开,甚至溢出视口底部.modal-body { max-height: calc(100vh - 120px); overflow-y: auto; }(减去 header/footer 高度).modal-content 上设 overflow,它会影响阴影和圆角渲染用 JS 动态初始化时,如果 modal-dialog 上漏了 modal-fullscreen 类,或者在 show 之前没补上,就会按默认尺寸弹出——而且这个行为不可逆,除非隐藏再重开。
new bootstrap.Modal(...).show(),DOM 渲染可能有微小延迟,稳妥做法是加个 setTimeout(..., 0) 或用 queueMicrotask
modal-fullscreen 写死在 HTML 里,JS 只负责触发;或者用 shown.bs.modal 事件补样式(但此时已渲染完毕,只能修修补补)mounted 或 useEffect 完成、真实 DOM 存在后再初始化 Modal 实例全屏 Modal 看似只是加个 class,但实际卡点都在细节:类加在哪一层、vh 在不同系统的表现、滚动容器的高度计算、以及 JS 初始化时机——这些地方错一个,就退回「看起来像全屏,实则处处别扭」的状态。