原文转自:http://blog.jobbole.com/53961/css
了解如何使用 Bootstrap 快速开发网站和 Web 应用程序(包括移动友好型应用程序)。Bootstrap 以 LESS 项目为基础,由 Twitter 的内部工程师开发,它为 Web 应用程序 UI 提供了一致的框架。html
浏览器开发人员最后将其支持全都汇集在标准上,好比 HTML五、级联样式表 2 级 (CSS2) 和 CSS3。这些标准减小了浏览器行为自 Web 全面启动开始以来困扰开发人员和设计人员的许多不合理变化。为了掩盖遗留问题并适应遗留浏览器,一些开发人员创做出了 Web 页面框架。这类工具使得即便是普通人也能够开发适合大多数用户的网站。jquery
其中一个最受欢迎的 Web 页面框架来自一个预料以外的来源。Twitter 的开发人员厌倦了设法解决用于网页开发的许多不一样组件。他们建立了单一的框架来提供 Web 页面设计中的最多见元素,同时支持合理的灵活性。他们以 Bootstrap(一种开源项目)的形式与全世界共享这一工具包。css3
Bootstrap 以 LESS 项目为基础,加强了 CSS 语言。Bootstrap 还包括基本的 CSS 元素,这些元素用于排印、表单、按钮、表格、网格、导航、警告等。Bootstrap 的主要目标是帮助 Web 开发人员加快其项目。这也是目前 GitHub 软件库中最受欢迎的项目。我的、小型团队,甚至大型组织都在使用 Bootstrap。git
本文将向您介绍如何使用 Bootstrap 快速开发网站和应用程序,包括移动友好型应用程序。本文反映了开发人员的观点,而不是设计人员的观点。要想从本文和 Bootstrap 中获益,您须要掌握 HTML 和 CSS 的应用知识。我在 “在 CSS 中使用 LESS 实现更多的功能” 中介绍的 LESS 项目的一些基本知识可帮助您了解本文的主要代码示例。github
下载已编译的 Bootstrap 数据包(参见 参考资料)。我在本文中使用的是 V2.3.2。下载内容包括 Bootstrap 的关键元素 CSS,以及一些有用的图像和 JavaScript 文件。您能够根据我在文中的描述为 Web 页面提供 HTML。(参见 下载 部分,获取本文的样例代码。)Bootstrap 文档中不包含框架支持的许多设计选项的样例 HTML。可是 Bootstrap 文档页面(尽管其自己已说明了 Bootstrap 的灵活性)还不足以解释真正起做用的基本设计原则。web
查看 Web 页面的设备包括小型移动电话,以及大于普通台式计算机外形规格的显示器。在响应式设计 中,一开始就在 Web 页面中构建了灵活性,这样用户就能够经过全部设备查看页面。响应式设计的核心是 CSS3 媒体查询,这是根据设备性质(尤为是用户的显示器大小)来调用 CSS 规则的一种标准方法。数据库
对于典型开发人员启动的各类项目,我建议首先使用启用了响应特性的固定布局。固定布局更易于组织,并且响应特性支持从一开始就培养考虑网站如何在移动设备上运行的良好习惯。若是项目要应用于生产环境中,并且您正在与设计人员合做,那么设计人员应可以使您的文件适用于更加适合的其余任何模型。bootstrap
清单 1 是一个有用的框架 HTML 文件,用于结合使用 Bootstrap 与一个固定布局和响应特性:浏览器
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
<!doctype html>
<html>
<head>
<title>Bootstrap 101 Template</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link href="css/bootstrap.min.css" rel="stylesheet" media="screen">
<link href="css/bootstrap-responsive.min.css" rel="stylesheet">
</head>
<body>
<h1>Hello world!</h1>
<div>
... <!-- The main HTML will go here -->
</div>
<script src="http://code.jquery.com/jquery.js"></script>
<script src="js/bootstrap.min.js"></script>
</body>
</html>
|
在 Bootstrap 下载中,请注意,每一个 CSS 和 JavaScript 文件有两个版本可用(例如 bootstrap.js 和 bootstrap.min.js)。第一种形式是一个常规文件,第二种形式是压缩文件或 “缩小文件”。就像在本文中同样,使用缩小版本便可实现最有效的页面加载。
listing1.html 的开始之处的 DOCTYPE
声明将其标记为一个 HTML5 文件。head
元素内的 meta
标记控制移动的小屏幕布局。(为方便起见,我将它们称做 meta/viewport
标记。)默认状况下,大多数移动设备按比例缩小 Web 页面,使之适应屏幕大小,就像在桌面浏览器窗口中同样。这就是为何许多网站上的文本和图像在手机浏览器中看起来很小的缘由。meta/viewport
声明中的 initial-scale=1.0
部分禁用了这一行为,告诉设备要保持页面的原有尺寸。该声明表示 Web 设计人员(在本例中为 Bootstrap)已经完成了实现较小屏幕的响应式设计这一任务,因此在默认状况下,不必采用蛮力方法。
稍后,清单 1 的 head
标记是 Bootstrap CSS 的连接。在文件的末尾,加载 jQuery 和 Bootstrap 实用程序 JavaScript。这些脚本在末尾运行可实现最佳性能。
当使用 Bootstrap(或任何 Web 支持文件集)时,您能够从多种方法中选择用来设置 HTML 和其余代码的方法。我建议您建立一个文件夹来存储本身的项目,而后将 Bootstrap 文件及其完整的文件夹结构复制到项目文件夹中。将您本身的 HTML 文件放在最顶层,并将您本身的 CSS、JavaScript 和图像文件放在相应的 Bootstrap 子文件夹中(这些文件夹的名称分别为 css、js 和 img)。而后,总体结构以下所示:
1
2
3
4
5
6
7
8
9
10
11
12
|
.
|—— index.html
|—— [Also any other site HTML]
|—— css
| |—— bootstrap.min.css
| |—— bootstrap-responsive.min.css
| |—— [Also nonminimized Bootstrap files plus site-specific CSS]
|—— js
| |—— bootstrap.min.js
| |—— [Also nonminimized Bootstrap files plus site-specific JavaScript]
|—— img
|—— [The PNGs that come with Bootstrap plus site-specific images]
|
meta/viewport
标记是当前的约定,用于将页面调整为设备的可视浏览器空间。万维网联盟 (World Wide Web Consortium, W3C) 正在准备一种替换机制,该机制以一种新的 CSS 规则的形式出现(参见 参考资料)。清单 1 中 meta/viewport
声明的等效 CSS 是:
1
2
3
4
|
@viewport {
width
: extend-to-zoom
100%
;
zoom:
1.0
;
}
|
目前,您能够将这个代码包含在您的 CSS 中,并在 HTML 中保留 meta/viewport
标记。当 CSS 形式受到普遍支持时,您就能够删除meta/viewport
声明。
清单 1 中的主要容器 div
表示使用 Bootstrap 的固定布局。放入该容器中的 HTML 合并到了 Bootstrap 的网格系统 中。
若是还能想起曾经看到过的大部分 Web 页面,那么您就会认识到它们被分红了一系列的块。位于页面顶部的块可能拥有一个徽标。导航可能位于左边或右边的块中,而内容索引可能也适合放在那个位置。甚至可能出现另外一个块包含一个脚注的状况。主要内容自己可能被划分红多个面板或块。过去,Web 设计人员经过使用 CSS 盒子模型(box model)手工设置全部这些块。
网格系统是将盒子布置(好比刚刚描述的)抽象为行和列的一种方法。Bootstrap 为此类网格提供了一个核心的 CSS。您能够经过使用特殊的类,经过嵌入 div
元素将内容放置在任何布局的盒子中。
图 1 显示了一个有用的模板,这个模板最初由 Aaron K. White 开发,用于可视化 Bootstrap 的网格系统并规划如何安排您的内容(参见 参考资料)。在本文中,我作了一些修改,以便在本文中更容易读取文本。
Bootstrap 网格系统的每一行最多有 12 块,每两个块之间留有小槽来提供间隔。您能够拥有无限数量的行,每一行的高度任您设置。每一个块是 70 像素宽,小槽是 30 像素宽。Bootstrap 还为页面正文设置一个 30 像素的左边距。网格系统的设计目标是进行基本的布置并为您分配空间,所以,在理想状况下,您只需关注要在网格中放入什么便可。
在 “在 CSS 中使用 LESS 实现更多的功能” 中,我使用了一个响应式设计示例(根据 developerWorks 博主 Bob Leah 的 示例)来展现 LESS 工具如何加强 CSS 语法。Bootstrap 是一种功能强大的工具,可简化来自该代码的许多关注。清单 2 是来自这篇文章的 HTML(代码 下载 中的 responsive.html),重写该 HTML(如 listing2.html),以便在 Bootstrap 的固定布局网格系统中运行它,并使用 Bootstrap 的响应特性进行补充:
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
53
54
55
56
57
58
59
|
<!doctype html>
<html lang="en-US">
<head>
<title>Responsive Bootstrap page</title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link href="css/bootstrap.min.css" rel="stylesheet" media="screen">
<link href="css/bootstrap-responsive.min.css" rel="stylesheet">
</head>
<body>
<div>
<h1>Hello world!</h1>
<div>
<div id="banner">
<!-- Photo by Jake Sutton
http://www.flickr.com/photos/44124405407@N01/510899838 -->
<img src="img/sky-slim.jpg">
</div>
</div>
<div>
<div id="main-content">
<p>Humpts dumptus in muro sedet
</p>
<p>Veni vidi vici
</p>
<p>Alea iacta est
</p>
<hr>
</div>
<div>
<div>One</div>
<div>
The quick brown fox jumps...
</div>
<div>
<div>Two</div>
<div>
Over the lazy dog...
</div>
</div>
<div>
<div>Three</div>
<div>
To get to the other side
</div>
</div>
</div>
</div>
<div>
<div id="footer">
© Nobody! This document is placed in the public domain.
</div>
</div>
</div>
<script src="http://code.jquery.com/jquery.js"></script>
<script src="js/bootstrap.min.js"></script>
</body>
</html>
|
在 清单 2 中,Bootstrap 删除了我须要在较旧的响应式设计代码中手动完成的任务。由于页面使用了 Bootstrap 的网格系统,因此我再也不须要使用专门的 CSS 来操做或调整盒子大小。仔细安排可视空间的 CSS 也不须要专门的 CSS,由于 Bootstrap 网格在各个块之间设置了很好的默认值。此外,我不须要任何 CSS 来进行媒体查询(media query)并在设计参数中设置响应,由于 Bootstrap 的响应特性会负责完成这些任务。
您能够在清单 2 中看到 div
标记的嵌套。嵌套的 div
使用了 Bootstrap 网格类。具备 container
类的 div
是整个固定网格布局的包装程序。具备 row
类的每一个 div
在网格中定义了盒子的一行。具备 span4
类的 div
定义了一个横跨 4 个盒子的块。具备 span12
类的 div
定义横跨 12 个盒子的块 — 页面的整个宽度。Bootstrap 有一个 spanN
类,可横跨从 1 到 12 的任意数量 N 的盒子。
图 2 显示了所生成的页面在移动浏览器中的外观(运行 Android 4.1.1 的 Samsung Galaxy S3 上的 Google Chrome):
图 2 中所示页面的主要元素的布置是正确的。可是页面缺乏让其更吸引眼球的样式元素,因此我将添加一些 CSS(样例代码 中的 main.css)来实现这一目标。Bootstrap CSS 自己是使用 LESS 编写的,但我一般高度推荐使用 LESS 而不是纯文本的 CSS。但在这个简单示例中,清单 3 中的纯文本的 CSS 就足够用了:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
.widget-content {
margin: 10px;
padding: 1px;
}
.widget-title {
font-weight: bold;
padding: 10px;
}
.widget-text {
padding: 10px;
}
#footer {
text-align: center;
font-size: small;
}
|
固然,清单 2 中的 HTML 如今须要 清单 3 中的特定于站点的 CSS 的一个附加连接。在 样例代码 中,包含 main.css 连接的已更新的 HTML 位于 main.html 文件中。图 3 显示告终果页面,其中的 main.css 更为美观:
对于我和其余许多人来讲,咱们的优点是代码和数据,而不是视觉和其余感官设计,因此 Bootstrap 就是一个极其宝贵的工具。我能够关注一个 Web 项目的基本代码和数据,并将其绘成初始形状,而后与设计人员合做来美化页面。Bootstrap 对一些特别微妙的领域颇有帮助,好比移动设备设计和其余小屏幕设置。它还附带了一个库,其中包含按钮、导航样式和其余可重用工具。最重要的是,Bootstrap 包含的大量代码可减小 Web 浏览器和平台之间的许多使人烦恼的变化。
如此多的项目都在使用 Bootstrap,以致于许多人如今能够当即识别出基于的 Bootstrap 的站点。这种识别有时候能够建立一种非首创性的效果。一名优秀的设计人员不只能够给使用 Bootstrap 生成的站点提供本身的不一样字符,并且还能够确保该站点的基本元素和响应元素都专用于其内容和使用。可是,只有少数几个项目开始研究这些考虑因素。Bootstrap 尤为适用于将思想的闪光点快速转变为 Web 项目。
描述 | 名字 | 大小 |
---|---|---|
样例代码 | wa-bootstrapcode.zip | 41KB |