- 响应式设计(Reponsive Web Design,简称 RWD)指的是不同的设备(电脑、平板、手机)访问相同的页面的时候,得到不同的页面视图,而得到的视图是适应当前屏幕的
# Bootstrap CSS
# 栅格系统(Grid System)
- class 前缀:.col-xs-*、.col-sm-*、.col-md-*、.col-lg-*,其中 * 范围是从 1 到 12
- 偏移列,使用 .col-md-offset-*类,这些类会把一个列的左外边距(margin)增加 * 列,其中 * 范围是从 1 到 11
<div class="container">
    <div class="row">
        <div class="col-*-*">...</div>
        <div class="col-*-*">...</div>
    </div>
    <div class="row">...</div>
</div>
1
2
3
4
5
6
7
2
3
4
5
6
7
# 排版
<small>本行内容是在标签内</small><br>
<strong>本行内容是在标签内</strong><br>
<em>本行内容是在标签内,并呈现为斜体</em><br>
<p class="text-left">向左对齐文本</p>
<p class="text-center">居中对齐文本</p>
<p class="text-right">向右对齐文本</p>
<p class="text-muted">本行内容是减弱的</p>
<p class="text-primary">本行内容带有一个 primary class</p>
<p class="text-success">本行内容带有一个 success class</p>
<p class="text-info">本行内容带有一个 info class</p>
<p class="text-warning">本行内容带有一个 warning class</p>
<p class="text-danger">本行内容带有一个 danger class</p>
1
2
3
4
5
6
7
8
9
10
11
12
2
3
4
5
6
7
8
9
10
11
12
# 代码
- <code> 同一行代码片段
- <pre> 多行代码
# 表格
- <table> 类 - .table为任意 <table> 添加基本样式 (只有横向分隔线)
- .table-striped在 <tbody> 内添加斑马线形式的条纹
- .table-bordered为所有表格的单元格添加边框
- .table-hover在 <tbody> 内的任一行启用鼠标悬停状态
- .table-condensed让表格更加紧凑
 
- <tr>, <th> 和 <td> 类 - .active将悬停的颜色应用在行或者单元格上
- .success表示成功的操作
- .info表示信息变化的操作
- .warning表示一个警告的操作
- .danger表示一个危险的操作
 
# 表单
# 垂直排列的表单(默认)
- 创建基本表单的步骤
- 向父 <form> 元素添加 role="form"。
- 把 <label> 和控件放在一个 <div class="form-group">中
- 向所有的文本元素 <input>、<textarea> 和 <select> 添加 class ="form-control"(设置宽度属性为width: 100%;)
 
- 向父 <form> 元素添加 
# 内联表单
- 向 <form> 标签添加 class .form-inline
# 水平排列的表单
- 向父 <form> 元素添加 class .form-horizontal,向标签添加 class.control-label
<form class="form-horizontal" role="form">
    <div class="form-group">
        <label class="col-sm-2 control-label">Email</label>
        <div class="col-sm-10">
            <p class="form-control-static">email@example.com</p>
        </div>
    </div>
    <div class="form-group">
        <label for="inputPassword" class="col-sm-2 control-label">密码</label>
        <div class="col-sm-10 has-error">
            <input type="password" class="form-control" id="inputPassword" placeholder="请输入密码">
        </div>
    </div>
</form>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
2
3
4
5
6
7
8
9
10
11
12
13
14
# 支持的表单控件
- Bootstrap 支持最常见的表单控件,主要是 input、textarea、checkbox、radio 和 select
# 表单控件状态
- 验证状态:Bootstrap 包含了错误、警告和成功消息的验证样式。只需要对父元素简单地添加适当的 class(.has-warning、.has-error或.has-success)即可使用验证状态
# 按钮
- 以下样式可用于 <a>, <button>, 或 <input> 元素上
- .btn为按钮添加基本样式
- .btn-default默认/标准按钮(灰色)
- .btn-primary原始按钮样式(未被操作)(蓝色)
- .btn-success表示成功的动作(绿色)
- .btn-info该样式可用于要弹出信息的按钮(浅蓝色)
- .btn-warning表示需要谨慎操作的按钮(黄色)
- .btn-danger表示一个危险动作的按钮操作(红色)
- .btn-link让按钮看起来像个链接(仍然保留按钮行为)
- .btn-lg制作一个大按钮
- .btn-sm制作一个小按钮
- .btn-xs制作一个超小按钮
- .btn-block块级按钮(拉伸至父元素100%的宽度)
- .active激活状态
- .disabled禁用状态
 
# 图片
- .img-rounded为图片添加圆角
- .img-circle将图片变为圆形
- .img-thumbnail缩略图功能
- .img-responsive图片响应式
# 辅助类
- 文本颜色:.text-muted、.text-primary、.text-success、.text-info、.text-warning、.text-danger
- 背景颜色:.bg-primary、.bg-success、.bg-info、.bg-warning、.bg-danger
# Bootstrap 布局组件
<!-- 字体图标(Glyphicons)-->
<span class="glyphicon glyphicon-search" style="color: blue; font-size: 60px;"></span> 搜索
<!-- 进度条 -->
<div class="progress progress-striped active">
    <div class="progress-bar " role="progressbar" aria-valuemin="0" aria-valuemax="100" style="width: 45%;">
        45%
    </div>
</div>
<!-- 标签 -->
<span class="label label-default">默认标签</span>
<span class="label label-primary">主要标签</span>
<span class="label label-success">成功标签</span>
<span class="label label-info">信息标签</span>
<span class="label label-warning">警告标签</span>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
# Bootstrap 插件
// 初始化为默认行为
$("#myModal").modal()
 // 初始化为不支持键盘
$("#myModal").modal({ keyboard: false })
// 初始化并立即调用 show
$("#myModal").modal('show')
$('#myModal').on('show.bs.modal', function () {
  // 执行一些动作...
})
1
2
3
4
5
6
7
8
9
2
3
4
5
6
7
8
9
# 模态框(Modal)插件
- $('#identifier').modal(options);
- 参数 
 backdrop: boolean 或字符串 'static' // 指定一个静态的背景,当用户点击模态框外部时不会关闭模态框
 keyboard: true // 键盘上的 esc 键被按下时关闭模态框
 show: true // 当初始化时显示模态框
 remote: path // 使用 jQuery.load 方法,为模态框的主体注入内容
- 方法 
 'toggle':手动切换模态框
 'show':手动打开模态框
 'hide':手动隐藏模态框
- 事件 
 'show.bs.modal' 在调用 show 方法后触发
 'shown.bs.modal' 当模态框对用户可见时触发
 'hide.bs.modal' 当调用 hide 实例方法时触发
 'hidden.bs.modal' 当模态框完全对用户隐藏时触发
<!-- Modal -->
<div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel">
    <div class="modal-dialog" role="document">
        <div class="modal-content">
            <div class="modal-header">
                <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span>
                </button>
                <h4 class="modal-title" id="myModalLabel">模态框标题</h4>
            </div>
            <div class="modal-body">
                模态框内容
            </div>
            <div class="modal-footer">
                <button type="button" class="btn btn-default" data-dismiss="modal">关闭</button>
                <button type="button" class="btn btn-primary">保存</button>
            </div>
        </div>
    </div>
</div>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
# 弹出框(Popover)插件
- $('#identifier').popover(options);
- 参数
 html:是否向弹出框插入 HTML,默认值:false
 title:弹出框标题
 content:弹出框内容,string | element | function
 trigger:定义如何触发弹出框:click| hover | focus | manual,可以传递多个触发器,每个触发器之间用空格分隔
 placement:规定如何定位弹出框:top | bottom | left | right | auto
# Bootstrap - jQuery - Plugin
# string
// "ASP is old, ASP.net is new, ASP long lives"
"{0} is old, {1} is new, {0} long lives".format("ASP", "ASP.net")
1
2
2
# dialog(对话框窗口)
<button class="btn btn-primary" onclick="run()">Run</button>
<div id="loginwrap">
    <form id="loginform" role="form">
        <div class="form-group">
            <label for="username">Username</label>
            <input type="username" class="form-control"
                   id="username">
        </div>
        <div class="form-group">
            <label for="password">Password</label>
            <input type="password" class="form-control"
                   id="password">
        </div>
    </form>
</div>
<script>
    $("#loginwrap").dialog({
        title: "Login",
        backdrop: "static", // with backdrop or keyboard
        autoOpen: false, // without auto open
        dialogClass: "modal-sm", // Optional sizes: "modal-lg" or "modal-sm"
        onClose: function () { // Override onClose event
            $(this).dialog("destroy");
        },
        buttons: [
            {
                text: "Close",
                'class': "btn-primary",
                click: function () {
                    $(this).dialog("close");
                }
            },
            {
                text: "Login",
                'class': "btn-success",
                click: function () {
                    /*your login handler*/
                }
            }
        ]
    });
    function run() {
        $("#loginwrap").dialog("open");
        // Rut the element to the old place, remove the overlay from DOM.
        // $("#loginwrap").dialog("destroy");
    }
</script>
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
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
# messager(消息窗口)
$.messager.alert("Title", "This is message!");
$.messager.model = {
    ok:{ text: "确定", classed: 'btn-success' },
    cancel: { text: "取消", classed: 'btn-danger' }
};
$.messager.confirm("title", "This is message!", function() {
    alert("you closed it")
});
$.messager.popup("This is message!");
1
2
3
4
5
6
7
8
9
10
11
2
3
4
5
6
7
8
9
10
11
# datagrid(数据表格)
# tree(树)
        Sponsor