1. CSS-12栅格系统
把网页宽度均分为12等分(保留15位精度)——这是bootstrap的核心功能。
2.基础布局组件
包括排版、按钮、表格、布局、表单等等。
3.jQuery
bootstrap插件的基础
4.响应式设计
兼容多个终端。这是bootstrap的终极理念。
5.css插件
提供丰富的样式。
6.js插件
二. 栅格系统
1.基本实现过程
定义容器的大小——跳转边距——媒询
有以下要求:
(1)一行(row)数据必须包含在.container中。
.container默认居中。宽度分为4种,超小屏(100%),小屏(750px),中屏(970px),大屏(1170px)。row的边距(左右margin,下同)是-15px。
(2)有了row,才能搭建列(col)。所有组件必须放在col内,只有col才能作为row的直接子元素。
.col的左右内边距(padding-left,right)为15px。也就是说,最小的col有30px。
(3)在以上基础上快速搭建布局
(4)col之间是木有边距的,应当使用padding来产生col的视觉距离。这样做会导致一个row容不下12个col,这时应当用负的margin来抵消padding的影响。
(5)栅格系统是通过指定1-12的值来设定范围的。对于col的规格,开发者指定了4个不同的屏幕
如图,在<body>内包含若干个<div>col-md-“1-12数字”></div>效果是
小结: col组合其实就用了两个属性:float:left和width%。
2. 实现方案
(1)偏移(.col-尺寸大小-offset-*)
把整个col向右边偏移,在源码实现上,.col-尺寸大小-offset-x 就是margin-left:8.33333333333...*x;
情景一:页面主体只占据container的66%,而且居中。
解决方案:col-md-offset-2——向右偏移了2个col。
<div>col-md8</div>
情景二:宽度足够的情况下,我不想所有的col紧紧挨在一起。两个要有1个col的距离。
<div>col-md8</div> <div>col-md3</div>
(2)嵌套
栅格系统的col是可以针对父级的row进一步再进行百分比的划分,比如说:
<div> <div>我是整行<br> <div>我是一半 <div> <div>我是6/12*6/12=1/4</div> </div> </div> <div></div> </div> </div>
(3)排序
强行把当前列向左或者向右推拉
只有两个语句:col-尺寸大小-push-*()和col-尺寸大小-pull-*()
<div> <div>col3</div> </div>
col3被强行推了6格。同理<div>col3</div>是向左拉了一格。
效果相当于绝对定位。在源码实现上,也是做定位:
.col-md-pull-8 { right: 66.66666666666666%;}
3.响应式栅格若干问题
看起来12列栅格布局实现得很死板,但是组合屏幕尺寸,方案就非常多了
(1)跨设备组合
比如我要为自己的网页做一适配小屏和中屏的版本,可以把类叠加到class上。
<div>col3</div>
在中屏表现是1/4。
到了小屏,表现为1/2
如果我定义一个
<div>col3</div>
到了大屏,依然占25%。
结论:屏幕尺寸向大兼容。向小肯定不兼容!
(2)清除浮动
情景:在小屏幕上一行显示4个col3,在超小屏幕上一行显示2个col6,代码如何实现?
代码应该是这样的
<div>col</div> <div>col</div> <div>col</div> <div>col</div>
看起来也没问题。
如果把第一个div改为
<div>col<br>我胖了</div>
效果不佳。
这时应该加一个清除浮动的div到第2/3个div之间第四个就不会飘上去了
<div>col<br>我胖了</div>
<div>col</div>
<div></div>
<div>col</div>
<div>col</div>
所谓class="clearfix visible-xs",前者表示清除浮动,后者表示在超小屏生效
(3)“强大”的偏移和排序——组合应用的demo