8.2.3 使用JS弹出对话框

8.2.3 使用JS弹出对话框

Bootstrap允许调用对话框的modal()方法来弹出对话框,该方法支持如下3种参数。

  1. 不传入参数:以默认方式打开对话框,这是最简单的方式。
  2. 传入字符串参数:Bootstrap支持传入'show''hide''toggle''handleUpdate'这几个字符串,分别表示显示对话框、隐藏对话框、切换对话框的隐藏显示状态、更新对话框位置。
  3. 传入JS对象。

modal的JS对象参数的属性

从以上介绍可以看出,第一种方式最为简单,第三种方式最为复杂,但功能最强大。当传入JS对象作为参数时,该JS对象可支持如下属性。

属性 描述
backdrop 相当于前面介绍的data-backdrop 属性,用于指定是否可通过单击背景来关闭对话框
keyboard 相当于前面介绍的data-keyboard属性,用于指定是否可通过键盘的Esc键来关闭对话框
show 相当于前面介绍的data-show属性,用于指定是否在页面加载时自动显示对话框
remote 该属性指定一个URL,该URL加载的内容将会显示在对话框的主体(被指定class="modal-body"的元素)内,但该属性从Bootstrap 3.3时已过时了,因此尽量避免使用该属性。

程序示例

如下代码示范了如何使用JS弹出对话框。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
<!DOCTYPE html>
<html>

<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1">
<title> 弹出对话框 </title>
<link rel="stylesheet" href="../bootstrap/css/bootstrap.min.css">
<link rel="stylesheet" href="../bootstrap/css/bootstrap-theme.min.css">
</head>

<body>
<!-- 通过调用modal()方法打开对话框 -->
<button type="button" class="btn btn-primary" onclick="$('#myModal').modal();">打开对话框
</button>
<button type="button" class="btn btn-primary" onclick="$('#myModal').modal({backdrop:false});">打开无背景对话框
</button>
<button type="button" class="btn btn-primary" onclick="$('#myModal').modal({keyboard:true});">可通过Esc关闭的对话框
</button>
<!-- 对话框整体容器 -->
<div class="modal fade" tabindex="-1" role="dialog" id="myModal">
<!-- 对话框 -->
<div class="modal-dialog" role="document">
<!-- 对话框内容 -->
<div class="modal-content">
<!-- 对话框头 -->
<div class="modal-header">
<!-- data-dismiss="modal"表示该按钮可关闭对话框 -->
<button class="close" type="button" data-dismiss="modal">
<span aria-hiden="true">&times;</span>
</button>
<h4>对话框</h4>
</div>
<!-- 对话框主体 -->
<div class="modal-body">
<p>对话框内容</p>
</div>
<!-- 对话框脚注 -->
<div class="modal-footer">
<!-- data-dismiss="modal"表示该按钮可关闭对话框 -->
<button class="btn btn-default" type="button" data-dismiss="modal">
关闭</button>
<button class="btn btn-primary" type="button">保存</button>
</div>
</div>
</div>
</div>
<script type="text/javascript" src="../jquery-3.1.1.js"></script>
<script type="text/javascript" src="../bootstrap/js/bootstrap.min.js"></script>
</body>

</html>

在代码中定义了3个按钮来打开对话框,

  • 点击第一个按钮时调用了无参数的modal()方法,该方法打开的对话框具有默认行为。
  • 点击第一个按钮时传入了{backdrop:false}对象,这意味着该对话框将不包括背景,且不可通过单击背景关闭对话框;
  • 点击第一个按钮时传入了{keyboard:true}对象,这意味着该对话框可通过键盘的Esc键来关闭。