弹出模态框
使用Bootstrap的JavaScript模式插件将对话框添加到站点中,用于lightbox、用户通知或完全自定义的内容。更新于: 2023-04-30 14:28:21 查看: 501
发布于: 2021-9-4 10:26 发布者: 大米
- Modals是用HTML、CSS和JavaScript构建的。它们被放置在文档中的所有其他内容之上,并从
<body>
中删除scroll,这样模态内容就可以滚动了。 - 点击模态“背景”将自动关闭模态。
- Bootstrap一次只支持一个模式窗口。我们不支持嵌套的modals,因为我们认为它们是糟糕的用户体验。
- Modals使用
position: fixed
,这有时对其渲染有点特殊。只要可能,请将模态HTML放在顶层位置,以避免来自其他元素的潜在干扰。在另一个固定元素中嵌套.modal
时,可能会遇到问题。 - 同样,由于
position: fixed
,在移动设备上使用modals有一些注意事项。有关详细信息, 请参阅我们的浏览器支持文档 。 - 由于HTML5如何定义它的语义,
autofocus
HTML属性 在Bootstrap模式中没有作用。要获得相同的效果,请使用一些自定义JavaScript:
var myModal = document.getElementById('myModal')
var myInput = document.getElementById('myInput')
myModal.addEventListener('shown.bs.modal', function () {
myInput.focus()
})
<div class="modal" tabindex="-1">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title">Modal title</h5>
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
</div>
<div class="modal-body">
<p>Modal body text goes here.</p>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Close</button>
<button type="button" class="btn btn-primary">Save changes</button>
</div>
</div>
</div>
</div>
<!-- Button trigger modal -->
<button type="button" class="btn btn-primary" data-bs-toggle="modal" data-bs-target="#exampleModal">
Launch demo modal
</button>
<!-- Modal -->
<div class="modal fade" id="exampleModal" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalLabel">Modal title</h5>
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
</div>
<div class="modal-body">
...
</div>
<div class="modal-footer">
<button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Close</button>
<button type="button" class="btn btn-primary">Save changes</button>
</div>
</div>
</div>
</div>
<!-- Button trigger modal -->
<button type="button" class="btn btn-primary" data-bs-toggle="modal" data-bs-target="#staticBackdrop">
Launch static backdrop modal
</button>
<!-- Modal -->
<div class="modal fade" id="staticBackdrop" data-bs-backdrop="static" data-bs-keyboard="false" tabindex="-1" aria-labelledby="staticBackdropLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="staticBackdropLabel">Modal title</h5>
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
</div>
<div class="modal-body">
...
</div>
<div class="modal-footer">
<button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Close</button>
<button type="button" class="btn btn-primary">Understood</button>
</div>
</div>
</div>
</div>
您还可以创建一个可滚动的模式,通过添加.modal-dialog-scrollable
到 .modal-dialog
允许滚动模式的身体 。
<!-- Scrollable modal -->
<div class="modal-dialog modal-dialog-scrollable">
...
</div>
<!-- Vertically centered modal -->
<div class="modal-dialog modal-dialog-centered">
...
</div>
<!-- Vertically centered scrollable modal -->
<div class="modal-dialog modal-dialog-centered modal-dialog-scrollable">
...
</div>
<div class="modal-body">
<h5>Popover in a modal</h5>
<p>This <a href="#" role="button" class="btn btn-secondary popover-test" title="Popover title" data-bs-content="Popover body content is set in this attribute.">button</a> triggers a popover on click.</p>
<hr>
<h5>Tooltips in a modal</h5>
<p><a href="#" class="tooltip-test" title="Tooltip">This link</a> and <a href="#" class="tooltip-test" title="Tooltip">that link</a> have tooltips on hover.</p>
</div>
<div class="modal-body">
<div class="container-fluid">
<div class="row">
<div class="col-md-4">.col-md-4</div>
<div class="col-md-4 ms-auto">.col-md-4 .ms-auto</div>
</div>
<div class="row">
<div class="col-md-3 ms-auto">.col-md-3 .ms-auto</div>
<div class="col-md-2 ms-auto">.col-md-2 .ms-auto</div>
</div>
<div class="row">
<div class="col-md-6 ms-auto">.col-md-6 .ms-auto</div>
</div>
<div class="row">
<div class="col-sm-9">
Level 1: .col-sm-9
<div class="row">
<div class="col-8 col-sm-6">
Level 2: .col-8 .col-sm-6
</div>
<div class="col-4 col-sm-6">
Level 2: .col-4 .col-sm-6
</div>
</div>
</div>
</div>
</div>
</div>
<div class="modal" tabindex="-1" aria-labelledby="..." aria-hidden="true">
...
</div>
尺寸 | 类 | Modal 最大宽度 |
---|---|---|
小 | .modal-sm |
300px |
默认 | None | 500px |
大 | .modal-lg |
800px |
超大 | .modal-xl |
1140px |
我们不带修饰符类别的默认模态构成“中等”尺寸模态 。
<div class="modal-dialog modal-xl">...</div>
<div class="modal-dialog modal-lg">...</div>
<div class="modal-dialog modal-sm">...</div>
类型 | 可利用性 |
---|---|
.modal-fullscreen |
总是 |
.modal-fullscreen-sm-down |
低于 576px |
.modal-fullscreen-md-down |
低于 768px |
.modal-fullscreen-lg-down |
低于 992px |
.modal-fullscreen-xl-down |
低于 1200px |
.modal-fullscreen-xxl-down |
低于 1400px |
<!-- Full screen modal -->
<div class="modal-dialog modal-fullscreen-sm-down">
...
</div>
通过数据属性
无需编写JavaScript即可激活模式。设置 data-bs-toggle="modal"
的控制器元件上,像一个按钮,以及一个 data-bs-target="#foo"
或 href="#foo"
,指定特定模态切换。
<button type="button" data-bs-toggle="modal" data-bs-target="#myModal">Launch modal</button>
通过JavaScript
用一行JavaScript创建一个模态:
var myModal = new bootstrap.Modal(document.getElementById('myModal'), options)
选项
可以通过数据属性或JavaScript传递选项。对于数据属性,将选项名称附加到中 data-bs-
,如中所示 data-bs-backdrop=""
。
名字 | 类型 | 默认 | 描述 |
---|---|---|---|
backdrop |
boolean or the string 'static' |
true |
包括一个模式背景元素。或者,指定static 不关闭点击模式的背景。 |
keyboard |
boolean | true |
按下退出键时关闭模式 |
focus |
boolean | true |
初始化时将重点放在模态上。 |
传递选项
将您的内容激活为模式。 接受一个可选的 object
对象。
var myModal = new bootstrap.Modal(document.getElementById('myModal'), {
keyboard: false
})
切换
手动切换模态。 在实际显示或隐藏模式之前 (即在 shown.bs.modal
或者 hidden.bs.modal
事件发生之前)返回调用方.
myModal.toggle()
显示
手动打开模式文件。 在模式实际显示之前(即在 shown.bs.modal
事件发生之前)。
myModal.show()
隐藏
手动隐藏模式。在实际隐藏模式之前(即 hidden.bs.modal
事件发生之前)返回调用方。
myModal.hide()
手动更新
如果模态的高度在打开时发生变化,则手动重新调整模态的位置(即,如果出现滚动条)。
myModal.handleUpdate()
处置
销毁元素的模态。(删除DOM元素上存储的数据)
myModal.dispose()
获取实例
允许您获取与DOM元素关联的模式实例的静态方法
var myModalEl = document.getElementById('myModal')
var modal = bootstrap.Modal.getInstance(myModalEl) // Returns a Bootstrap modal instance
事件
Bootstrap的modal类公开了一些事件,用于连接到modal功能。所有模态事件都在模态本身触发(即在 <div class="modal">
)。
事件类型 | 描述 |
---|---|
show.bs.modal |
show 调用实例方法时,将立即触发此事件。如果是由单击引起的,则clicked元素可用作 relatedTarget 事件的属性。 |
shown.bs.modal |
当模式对用户可见时将触发此事件(将等待CSS转换完成)。如果是由单击引起的,则clicked元素可用作 relatedTarget 事件的属性。 |
hide.bs.modal |
调用 hide 实例后,将立即触发此事件。 |
hidden.bs.modal |
在向用户隐藏模式后,将触发此事件(将等待CSS转换完成)。 |
hidePrevented.bs.modal |
当显示模态时显示此事件,其背景为, static 并在模态外部单击或使用键盘选项或 data-bs-keyboard 将设置为来执行退出键
false 。
|
var myModalEl = document.getElementById('myModal')
myModalEl.addEventListener('hidden.bs.modal', function (event) {
// do something...
})