1、栅格系统实现布局的原理

1)Bootstrap把屏幕的宽度拆分成12格(列),每一格像素的多少由设备屏幕分辨率决定,我们在开发项目的过程中不需要去指定像素或者百分比。

2)不同范围的分辨率对应不同设备

超小屏幕 手机(<768px)                   类的前缀:-col-xs-

小屏幕 平板(>=768px<992px)      类的前缀:-col-sm-

中等屏幕 桌面显示器(>=992px<1200px)类的前缀:-col-md-

大屏幕 大桌面显示器(>=1200px)      类的前缀:-col-lg-

在不同分辨率的屏幕下,自适应屏幕。

3)媒体查询

指定在某些分辨率下执行某些CSS样式

@media (max-width: 767px) {
div{background: red}
}

@media (min-width: 768px)and (max-width: 991px){
div{background: black;}
}

@media(min-width:992px)and(max-width:1199){

div{background: green;}

}
@media (min-width: 1200px) {
div{background: red;}
}

解读:宽度像素小于767px时,执行div{background:black;},宽度在768~1199px时执行div{background: black;},在992~1199px时执行div{background: green;}宽度大于等于1200px时执行div{background: red;}也就是说:在特定屏幕分辨率下执行不同(特定)样式。

2、栅格系统布局的使用

1)html内容在不同浏览器宽度所显示的宽度由.container中的属性决定

<div class="container">container</div>

小于768px------------------------None(自动)

大于等于768px小于992px--------750px

大于等于992px小于1200px-------970px

大于等于1200px-------------------1170px

系统会自动识别浏览器分辨率,设置div的宽度

2).container与.container-fluid区别

<div class="container">container</div>

按照设备浏览器窗口宽度设置对应的div宽度

<div class="container">container-fluid</div>

宽度100%显示,即100%宽度显示div

3)列组合(宽度12等分)

<div class="container">
  <div class="row">
    <div class="col-md-1">col-md-1</div>
    <div class="col-md-1">col-md-1</div>
    <div class="col-md-1">col-md-1</div>
    <div class="col-md-1">col-md-1</div>
    <div class="col-md-1">col-md-1</div>
    <div class="col-md-1">col-md-1</div>
    <div class="col-md-1">col-md-1</div>
    <div class="col-md-1">col-md-1</div>
    <div class="col-md-1">col-md-1</div>
    <div class="col-md-1">col-md-1</div>
    <div class="col-md-1">col-md-1</div>
    <div class="col-md-1">col-md-1</div>
  </div>
</div>

<div class="container">
  <div class="row">
    <div class="col-md-6">col-xs-6</div>
    <div class="col-md-6">col-xs-6</div>
  </div>
</div>

宽度2等分,每等分占6格。xs表示超小屏幕分辨率,当浏览器窗口变大时(大分辨率下),还是2等分,每等分占6格,1:1。也就是说小分辨率兼容大分辨率

4)列偏移

.col-xs-offset-2

.col-sm-offset-2

.col-md-offset-2

.col-lg-offset-2

列偏移之前:

<div class="container">
  <div class="row">
    <div class="col-md-2">col-md-2</div>
    <div class="col-md-4">col-md-4</div>
  </div>
</div>

偏移之后:

<div class="container">
  <div class="row">
    <div class="col-md-2 col-md-offset-2 ">col-md-2 col-md-offset-2</div>
    <div class="col-md-4 col-md-offset-3 ">col-md-4 col-md-offset-3</div>
  </div>
</div>

5)列嵌套

列嵌套之前:

<div class="container">
  <div class="row">
    <div class="col-md-9">9</div>
    <div class="col-md-3">3</div>
  </div>
</div>

列嵌套之后:

<div class="container">
  <div class="row">
    <div class="col-md-9">
      <div class="row">
        <div class="col-md-6">col-md-6</div>
        <div class="col-md-6">col-md-6</div>
      </div>
    </div>
  <div class="col-md-3">3</div>
</div>
</div>

6)列的排序

col-md-push-5向右推几格

col-md-pull-2向左拉几格

排序前:

<div class="container">
  <div class="row">
    <div class="col-md-3 ">col-md-3 </div>
    <div class="col-md-2 ">col-md-2</div>
  </div>
</div>

排序后:

<div class="container">
  <div class="row">
    <div class="col-md-3 col-md-push-5">col-md-3 </div>
    <div class="col-md-2 col-md-pull-2">col-md-2</div>
  </div>
</div>

7)跨设备的定义组合

<div class="container">
  <div class="row">
    <div class="col-md-8 col-sm-2 col-xs-6">8 </div>
    <div class="col-md-4 col-sm-10 col-xs-6">4</div>
  </div>
</div>
不同分辨率下不同的排列方式

8)清除浮动

<div class="container">
<div class="row">
<div class="col-xs-6 col-sm-3 ">col-xs-6 col-sm-3</div>
<div class="col-xs-6 col-sm-3 ">col-xs-6 col-sm-3</div>
<div class="col-xs-6 col-sm-3 ">col-xs-6 col-sm-3</div>
<div class="col-xs-6 col-sm-3 ">col-xs-6 col-sm-3</div>
</div>
</div>
在超小屏幕下(xs)一行就能排完:

在小屏幕下(sm)要排两行:

当第一列内容比较多,占2行的话则(超小屏幕下xs):

<div class="container">
  <div class="row">
    <div class="col-xs-6 col-sm-3 ">col-xs-6 col-sm-3内容比较多3内容比较多内容比较多内容比较多 </div>
    <div class="col-xs-6 col-sm-3 ">col-xs-6 col-sm-3</div>
    <div class="col-xs-6 col-sm-3 ">col-xs-6 col-sm-3</div>
    <div class="col-xs-6 col-sm-3 ">col-xs-6 col-sm-3</div>
  </div>
</div>

如果要使第三列排列在下一行,就需要清除浮动:clearfix visible-xs

<div class="container">
  <div class="row">
    <div class="col-xs-6 col-sm-3 ">col-xs-6 col-sm-3内容比较多3内容比较多内容比较多内容比较多 </div>
    <div class="col-xs-6 col-sm-3 ">col-xs-6 col-sm-3</div>
    <div class="clearfix visible-xs"></div>
    <div class="col-xs-6 col-sm-3 ">col-xs-6 col-sm-3</div>
    <div class="col-xs-6 col-sm-3 ">col-xs-6 col-sm-3</div>
  </div>
</div>

9)禁止响应布局

不要移动设备优先:<meta name="viewport" content="width=device-width, initial-scale=1">设置传统web模式

本文系作者原创,转载请注明出处,感谢合作!文章难免会有不足之处,如有纰漏,非常感谢您的指出,您可追加评论,或者QQ留言。



Bootstrap栅格系统用法--Bootstrap基础的更多相关文章

  1. 初学bootstrap ---栅格系统

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  2. Bootstrap 栅格系统初识

    以下理论内容copy自bootstrap中文网(一个不错的bootstrap学习网站). 栅格系统 Bootstrap 提供了一套响应式.移动设备优先的流式栅格系统,随着屏幕或视口(viewport) ...

  3. 巧用 BootStrap --- 栅格系统(布局)轻松搞定网页响应式布局!

    摘要:Bootstrap 为我们提供了一套响应式.移动设备优先的流式栅格系统,合理的使用栅格系统将会使得网站页面布局变得更加简单,在设置了媒体查询之后,响应式网站也无需再单独写了.接下来我以Boots ...

  4. Bootstrap栅格系统详解,响应式布局

    Bootstrap栅格系统详解 栅格系统介绍 Bootstrap 提供了一套响应式.移动设备优先的流式栅格系统,随着屏幕或视口(viewport)尺寸的增加,系统会自动分为最多12列. 栅格系统用于通 ...

  5. Bootstrap 栅格系统(转载)

    源地址:http://www.cnblogs.com/linjiqin/p/3559800.html Bootstrap 栅格系统 目录1.简介2.栅格选项3.列偏移4.嵌套列5.列排序 1.简介Bo ...

  6. Bootstrap栅格系统(布局)

    栅格系统(布局) Bootstrap内置了一套响应式.移动设备优先的流式栅格系统,随着屏幕设备或视口(viewport)尺寸的增加,系统会自动分为最多12列. 我在这里是把Bootstrap中的栅格系 ...

  7. 入门——Bootstrap栅格系统

    作为刚接触到Bootstrap框架的新手一枚,刚开始对Bootstrap中的栅格系统一脸懵逼,后来经过反复的上网查找资料以及自己一直在练习,总算对栅格系统了解个差不多,所以我将我所了解的当成是日记写下 ...

  8. Bootstrap栅格系统基本使用

    1.什么是栅格系统: 在Bootstrap中,它提供了一套响应式.移动设备优先的流式栅格系统,随着屏幕或视口(viewport)尺寸的增加,系统会自动分为最多12列.栅格系统用于通过一系列的行(row ...

  9. 第二百三十五节,Bootstrap栅格系统

    Bootstrap栅格系统 学习要点: 1.移动设备优先 2.布局容器 3.栅格系统 本节课我们主要学习一下 Bootstrap 的栅格系统,提供了一套响应式.移动设备优先的流 式栅格系统. 一.移动 ...

随机推荐

  1. CSS选择器 - 性能的探究及提升

    [本博客为原创:http://www.cnblogs.com/HeavenBin/]  前言: 在工作中编写CSS样式表时随着选择器层数的增加总会看到选择器又丑又长的情况,利用工作之余研究从其命名再到 ...

  2. Windows Firewall Setting

    If our web site hosted on web server canot be accessed by other computer by public network, one of t ...

  3. 陈年佳酿之 - Winform ListView 控件 double click 事件中获取选中的row与column

    背景 最近收到了一个关于以前项目的维护请求,那时的楼主还是刚刚工作的小青年~~~ 项目之前使用的是.net/winform.今天重新打开代码,看着之前在FrameWork2.0下面的代码, 满满的回忆 ...

  4. c语言 进程控制---创建进程 vfork()函数

    #include "stdio.h" #include "unistd.h" #include "sys/types.h" int gvar ...

  5. 8.13.2 TreeSet实现Comparable接口的两种方式

    推荐使用第二种方式,编写比较器可以使数据类的程序耦合度降低,同时比较器也可以重复利用! 第一种方式:数据类实现Comparable接口,实现其中的compareTo方法 创建对象时,使用TreeSet ...

  6. java 面试,如何提升自己的实力,摘自 java web轻量级开发面试教程

    本内容摘自 java web轻量级开发面试教程 其中有一段讲述到了实习经验对找工作的帮助 1.2.2大学阶段的实习经验能帮到你 一般公司在筛选简历时,一个非常重要考察的要点是相关经验的工作年限,说一个 ...

  7. 读书笔记--C陷阱与缺陷(一)

    要参与C语言项目,于是作者只好重拾C语言(之前都是C++,还是C++方便). 看到大家都推荐看看  C陷阱与缺陷(C traps and pitfalls),于是好奇的开始了这本书的读书之旅. 决定将 ...

  8. #define和typedef在windows上的应用

    typedef的应用 typedef是在计算机编程语言中用来为复杂的声明定义简单的别名. 下面的代码定义了一些常见类型的别名 typedef int INT; typedef unsigned int ...

  9. python汉字输出编码问题

    python中文输出乱码问题困扰了多少初学者,我在这方面栽了不知道多少跟头.现在我把我碰到的问题和解决的方法写出来与大家分享一下: 1输出乱码 所谓的乱码是指“鎴戞槸涓枃瀛楃涓”这样的内容.为什么 ...

  10. Android-Error3:Error when loading the SDK

    解决方法: 用C:\android\sdk\tools中的devices.xml将出现错误的地方的devices.xml替换掉既可以了.