Angular 模态框组件 | ng-hub-ui-modal

无障碍的 Angular 模态框组件,支持堆叠、全屏模式、模板、键盘处理和 CSS 变量,适用于 standalone 应用。

API 参考

这里是 modal 的完整契约:你可以绑定、监听、投影和设置主题的一切,都集中在一处。接入你需要的部分,自定义你想要的样式——它是 standalone 的,且对 signal 友好。

输入

通过 14 个输入项精细调校 modal。像绑定任意 Angular @Input 一样绑定它们。

名称类型默认值描述
animationboolean若为 true,模态框的打开和关闭将带有动画。默认值:true
backdropboolean | "static"若为 true,将创建背景遮罩元素。或者指定 "static" 以创建点击时不关闭模态框的背景遮罩。默认值:true
centeredboolean若为 true,模态框将垂直居中。默认值:false
placementHubModalPlacement控制模态框在视口中的放置位置。默认值:HubModalPlacement.Center
keyboardboolean若为 true,按下 Escape 键时模态框将关闭。默认值:true
closeOnNavigationboolean若为 true,当用户在浏览器历史中后退时(history.back()、浏览器后退按钮),模态框将关闭。默认值:true
size"sm" | "lg" | "xl" | string模态框窗口的尺寸
windowClassstring附加到模态框窗口的自定义类
backdropClassstring附加到模态框背景遮罩的自定义类
dismissSelectorstring可触发模态框窗口关闭(dismiss)的元素的自定义选择器。默认值:"[data-dismiss=\"modal\"]"
closeSelectorstring可触发模态框窗口关闭(close)的元素的自定义选择器。默认值:"[data-close=\"modal\"]"
headerSelectorstring模态框窗口头部元素的自定义选择器
footerSelectorstring模态框窗口底部元素的自定义选择器
dataany打开模态框窗口时需要传递的额外数据

输出

尚未记录任何输出项。

模板

打造你自己的样式——1 个模板插槽让你可以投影自定义标记。

名称描述示例
Modal Template可传递给 modal 服务的模板引用<ng-template #modalTemplate let-close="close" let-dismiss="dismiss"> <div class="modal-header"> <h4 class="modal-title">Modal Title</h4> </div> <div class="modal-body"> Modal content goes here </div> <div class="modal-footer"> <button class="btn btn-secondary" (click)="dismiss()">Cancel</button> <button class="btn btn-primary" (click)="close('result')">OK</button> </div> </ng-template>

CSS 变量

用 17 个 CSS 变量为每一个像素设置主题。在 :root 处覆盖它们,或将其限定到某个容器范围内。

Modal 基础变量

用于 modal 结构和定位的核心样式变量

变量默认值类型描述
--bs-modal-zindex1055number 模态框的 z-index
--bs-modal-width500pxlength 模态框的默认宽度
--bs-modal-padding1remlength 模态框内容周围的内边距
--bs-modal-margin0.5remlength 模态框对话框周围的外边距

Modal 外观

控制 modal 颜色、边框和视觉效果的变量

变量默认值类型描述
--bs-modal-colorvar(--bs-body-color)color 模态框内容的文本颜色
--bs-modal-bgvar(--bs-body-bg)color 模态框内容的背景颜色
--bs-modal-border-colorvar(--bs-border-color-translucent)color 模态框的边框颜色
--bs-modal-border-widthvar(--bs-border-width)border 模态框的边框宽度
--bs-modal-border-radiusvar(--bs-border-radius-lg)border 模态框的边框圆角
--bs-modal-box-shadow0 0.125rem 0.25rem rgba(0, 0, 0, 0.075)shadow 模态框的阴影

Modal 头部

modal 头部区域的样式变量

变量默认值类型描述
--bs-modal-header-padding-x1remlength 模态框头部的水平内边距
--bs-modal-header-padding-y1remlength 模态框头部的垂直内边距
--bs-modal-header-border-colorvar(--bs-border-color)color 模态框头部的边框颜色
--bs-modal-header-border-width0 0 var(--bs-border-width) 0border 模态框头部的边框宽度

Modal 底部

modal 底部区域的样式变量

变量默认值类型描述
--bs-modal-footer-gap0.5remlength 模态框底部各元素之间的间距
--bs-modal-footer-border-colorvar(--bs-border-color)color 模态框底部的边框颜色
--bs-modal-footer-border-widthvar(--bs-border-width) 0 0 0border 模态框底部的边框宽度

样式与主题

尚未记录任何样式示例。本节将包含自定义方案和主题示例。