Bootstrap 5 Modal淡入淡出由.fade和.show类共同控制,.fade定义opacity与transform过渡,.show激活动画;仅当二者共存时生效,移除.fade即禁用动画。
bootstrap 5 的 modal 动画完全依赖 .fade 和 .show 这两个类的组合,不是 js 控制的过渡时长或关键帧。默认情况下,.fade 定义了 opacity 和 transform 的过渡,.show 在显示时激活这些值。
关键点:动画只在元素同时拥有 .fade 和 .show 时生效;移除 .fade 就彻底禁用淡入淡出,变成硬切。
.fade 类本身包含 transition: opacity .15s linear, transform .15s ease-out
.modal.fade .modal-dialog 设置了初始 transform: translate(0, -50px)
.modal.fade.show .modal-dialog 覆盖为 transform: none,触发位移+透明度变化直接覆盖 Bootstrap 的 CSS 变量或重写 .fade 相关规则即可,无需修改 JS。优先用 CSS 变量(Bootstrap 5.3+ 支持),否则用显式样式。
推荐方式(在你的自定义 CSS 中):
:root { --bs-modal-fade-transform: translateY(-20px); --bs-modal-fade-transition: opacity 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);}.modal.fade .modal-dialog { transform: var(--bs-modal-fade-transform);}.modal.fade.show .modal-dialog { transform: none;}.fade { transition: var(--bs-modal-fade-transition);}
--bs-modal-fade-transform 控制入场起始位置(如 scale(0.95) 也能用)--bs-modal-fade-transition 同时调整 opacity 和 transform 的时长与缓动transition: all —— 容易干扰其他属性,且不兼容旧版 Bootstrap有时你只想让模态框“啪”一下弹出来,但 backdrop 仍要渐显。这时不能简单删掉 .fade,因为 backdrop 的 .modal-backdrop.fade 动画也依赖它。
.modal 元素单独移除 .fade,但保留 .modal-backdrop 上的 .fade
.show 到 .modal 和 .modal-backdrop,并确保 backdrop 的 opacity 过渡独立生效.fade 类,同时保留 backdrop 的 fade 行为示例(初始化后执行):
const myModal = new bootstrap.Modal(document.getElementById('myModal'));myModal._element.classList.remove('fade'); // 移除 modal 自身的 fade// backdrop 仍带 fade,不受影响
常见原因是选择器权重不够,或者没命中正确的元素层级。Bootstrap 的动画规则写在 .modal.fade .modal-dialog,而不是直接作用于 .modal。
.my-custom-modal { animation: ... } —— 必须匹配到 .modal.fade .modal-dialog 或其子元素!important,改用更具体的选择器,比如 .modal.my-modal.fade .modal-dialog
transition 和 transform 是否被覆盖或被禁用(如 transition: none)data-bs-animation="false"(Bootstrap 5.3+ 新属性),会强制跳过所有 fade 行为 —— 这个属性比 CSS 更优先动画逻辑本身很简单,但容易卡在 CSS 层叠和选择器精度上。动手前先 inspect 元素,看哪条 transition 规则最终生效,比猜更快。