查看: 1800|回复: 0

[JavaScript/JQuery] Bootstrap框架菜鸟入门教程

发表于 2017-9-23 08:00:01
句号论坛

Bootstrap菜鸟入门教程

Bootstrap简介

Bootstrap,来自 Twitter,是目前最受欢迎的前端框架。Bootstrap 是基于 HTML、CSS、JAVASCRIPT 的,它简洁灵活,使得 Web 开发更加快捷。


一、栅格系统

栅格系统的工作原理:

  • “行(row)”必须包含在 .container (固定宽度)或 .container-fluid (100% 宽度)中,以便为其赋予合适的排列(aligment)和内补(padding)。
  • 通过“行(row)”在水平方向创建一组“列(column)”。
  • 你的内容应当放置于“列(column)”内,并且,只有“列(column)”可以作为行(row)”的直接子元素。
  • 类似 .row 和 .col-xs-4 这种预定义的类,可以用来快速创建栅格布局。Bootstrap 源码中定义的 mixin 也可以用来创建语义化的布局。
  • 通过为“列(column)”设置 padding 属性,从而创建列与列之间的间隔(gutter)。通过为 .row 元素设置负值 margin 从而抵消掉为 .container 元素设置的 padding,也就间接为“行(row)”所包含的“列(column)”抵消掉了padding。
  • 负值的 margin就是下面的示例为什么是向外突出的原因。在栅格列中的内容排成一行。
  • 栅格系统中的列是通过指定1到12的值来表示其跨越的范围。例如,三个等宽的列可以使用三个 .col-xs-4 来创建。
  • 如果一“行(row)”中包含了的“列(column)”大于 12,多余的“列(column)”所在的元素将被作为一个整体另起一行排列。
  • 栅格类适用于与屏幕宽度大于或等于分界点大小的设备 , 并且针对小屏幕设备覆盖栅格类。 因此,在元素上应用任何 .col-md-* 栅格类适用于与屏幕宽度大于或等于分界点大小的设备 , 并且针对小屏幕设备覆盖栅格类。 因此,在元素上应用任何 .col-lg-* 不存在, 也影响大屏幕设备。

媒体查询:

  • 媒体查询是非常别致的"有条件的 CSS 规则"。它只适用于一些基于某些规定条件的 CSS。如果满足那些条件,则应用相应的样式。
  • Bootstrap 中的媒体查询允许您基于视口大小移动、显示并隐藏内容。下面的媒体查询在 LESS 文件中使用,用来创建 Bootstrap 网格系统中的关键的分界点阈值。
  1. /* 超小屏幕(手机,小于 768px) */
  2. /* 没有任何媒体查询相关的代码,因为这在 Bootstrap 中是默认的(还记得 Bootstrap 是移动设备优先的吗?) */
  3. /* 小屏幕(平板,大于等于 768px) */
  4. @media (min-width: @screen-sm-min) { ... }
  5. /* 中等屏幕(桌面显示器,大于等于 992px) */
  6. @media (min-width: @screen-md-min) { ... }
  7. /* 大屏幕(大桌面显示器,大于等于 1200px) */
  8. @media (min-width: @screen-lg-min) { ... }
复制代码

  • 有时候也会在媒体查询代码中包含 max-width,从而将 CSS 的影响限制在更小范围的屏幕大小之内。
  1. @media (max-width: @screen-xs-max) { ... }
  2. @media (min-width: @screen-sm-min) and (max-width: @screen-sm-max) { ... }
  3. @media (min-width: @screen-md-min) and (max-width: @screen-md-max) { ... }
  4. @media (min-width: @screen-lg-min) { ... }
复制代码
  • 媒体查询有两个部分,先是一个设备规范,然后是一个大小规则。在上面的案例中,设置了下列的规则:
  1. @media (min-width: @screen-sm-min) and (max-width: @screen-sm-max) { ... }
复制代码
  • 对于所有带有 min-width: @screen-sm-min 的设备,如果屏幕的宽度小于 @screen-sm-max,则会进行一些处理。

栅格参数

下表可以详细查看 Bootstrap 的栅格系统是如何在多种屏幕设备上工作的。

下表总结了 Bootstrap 网格系统如何跨多个设备工作

响应式的列重置

以下实例包含了4个网格,但是我们在小设备浏览时无法确定网格显示的位置。

为了解决这个问题,可以使用 .clearfix class和响应式工具来解决,如下面实例所示:

  1. <div class="container">
  2. <div class="row" >
  3. <div class="col-xs-6 col-sm-3"
  4. style="background-color: #dedef8;
  5. box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
  6. <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit.</p>
  7. </div>
  8. <div class="col-xs-6 col-sm-3"
  9. style="background-color: #dedef8;box-shadow:
  10. inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
  11. <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do
  12. eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut
  13. enim ad minim veniam, quis nostrud exercitation ullamco laboris
  14. nisi ut aliquip ex ea commodo consequat.
  15. </p>
  16. <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do
  17. eiusmod tempor incididunt ut.
  18. </p>
  19. </div>
  20. <div class="clearfix visible-xs"></div>
  21. <div class="col-xs-6 col-sm-3"
  22. style="background-color: #dedef8;
  23. box-shadow:inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
  24. <p>Ut enim ad minim veniam, quis nostrud exercitation ullamco
  25. laboris nisi ut aliquip ex ea commodo consequat.
  26. </p>
  27. </div>
  28. <div class="col-xs-6 col-sm-3"
  29. style="background-color: #dedef8;box-shadow:
  30. inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
  31. <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do
  32. eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut
  33. enim ad minim
  34. </p>
  35. </div>
  36. </div>
  37. </div>
复制代码

偏移列

偏移是一个用于更专业的布局的有用功能。它们可用来给列腾出更多的空间。例如,.col-xs-* 类不支持偏移,但是它们可以简单地通过使用一个空的单元格来实现该效果。

为了在大屏幕显示器上使用偏移,请使用 .col-md-offset-* 类。这些类会把一个列的左外边距(margin)增加 * 列,其中 * 范围是从 111

在下面的实例中,我们有

..
,我们将使用 .col-md-offset-3 class 来居中这个 div。

  1. <div class="container">
  2. <h1>Hello, world!</h1>
  3. <div class="row" >
  4. <div class="col-xs-6 col-md-offset-3"
  5. style="background-color: #dedef8;box-shadow:
  6. inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
  7. <p>Lorem ipsum dolor sit amet, consectetur adipisicing
  8. elit.
  9. </p>
  10. </div>
  11. </div>
  12. </div>
复制代码

嵌套列

为了在内容中嵌套默认的网格,请添加一个新的 .row,并在一个已有的 .col-md-* 列内添加一组 .col-md-* 列。被嵌套的行应包含一组列,这组列个数不能超过12(其实,没有要求你必须占满12列)。

在下面的实例中,布局有两个列,第二列被分为两行四个盒子。

  1. <div class="container">
  2. <h1>Hello, world!</h1>
  3. <div class="row">
  4. <div class="col-md-3" style="background-color: #dedef8;box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
  5. <h4>第一列</h4>
  6. <p>
  7. Lorem ipsum dolor sit amet, consectetur adipisicing elit.
  8. </p>
  9. </div>
  10. <div class="col-md-9" style="background-color: #dedef8;box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
  11. <h4>第二列 - 分为四个盒子</h4>
  12. <div class="row">
  13. <div class="col-md-6" style="background-color: #B18904; box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
  14. <p>
  15. Consectetur art party Tonx culpa semiotics. Pinterest
  16. assumenda minim organic quis.
  17. </p>
  18. </div>
  19. <div class="col-md-6" style="background-color: #B18904; box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
  20. <p>
  21. sed do eiusmod tempor incididunt ut labore et dolore magna
  22. aliqua. Ut enim ad minim veniam, quis nostrud exercitation
  23. ullamco laboris nisi ut aliquip ex ea commodo consequat.
  24. </p>
  25. </div>
  26. </div>
  27. <div class="row">
  28. <div class="col-md-6" style="background-color: #B18904; box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
  29. <p>
  30. quis nostrud exercitation ullamco laboris nisi ut
  31. aliquip ex ea commodo consequat.
  32. </p>
  33. </div>
  34. <div class="col-md-6" style="background-color: #B18904; box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
  35. <p>
  36. Lorem ipsum dolor sit amet, consectetur adipisicing elit,
  37. sed do eiusmod tempor incididunt ut labore et dolore magna
  38. aliqua. Ut enim ad minim.
  39. </p>
  40. </div>
  41. </div>
  42. </div>
  43. </div>
  44. </div>
复制代码

列排序

Bootstrap 网格系统另一个完美的特性,就是您可以很容易地以一种顺序编写列,然后以另一种顺序显示列。

您可以很轻易地改变带有 .col-md-push-*.col-md-pull-* 类的内置网格列的顺序,其中 * 范围是从 111

在下面的实例中,我们有两列布局,左列很窄,作为侧边栏。我们将使用 .col-md-push-*.col-md-pull-* 类来互换这两列的顺序。

  1. <div class="container">
  2. <h1>Hello, world!</h1>
  3. <div class="row">
  4. <p>
  5. 排序前
  6. </p>
  7. <div class="col-md-4" style="background-color: #dedef8; box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
  8. 我在左边
  9. </div>
  10. <div class="col-md-8" style="background-color: #dedef8; box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
  11. 我在右边
  12. </div>
  13. </div>
  14. <br>
  15. <div class="row">
  16. <p>
  17. 排序后
  18. </p>
  19. <div class="col-md-4 col-md-push-8" style="background-color: #dedef8; box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
  20. 我在左边
  21. </div>
  22. <div class="col-md-8 col-md-pull-4" style="background-color: #dedef8; box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
  23. 我在右边
  24. </div>
  25. </div>
  26. </div>
复制代码

二、Bootstrap 排版
  • HTML 中的所有标题标签,

    均可使用。另外,还提供了 .h1 到 .h6 类,为的是给内联(inline)属性的文本赋予标题的样式。
  1. <h1>我是标题1 h1</h1>
  2. <h2>我是标题2 h2</h2>
  3. <h3>我是标题3 h3</h3>
  4. <h4>我是标题4 h4</h4>
  5. <h5>我是标题5 h5</h5>
  6. <h6>我是标题6 h6</h6>
复制代码

  • 在标题内还可以包含 标签或赋予 .small 类的元素,可以用来标记副标题。

    如果需要向任何标题添加一个内联子标题,只需要简单地在元素两旁添加 ,或者添加 .small class,这样子您就能得到一个字号更小的颜色更浅的文本,如下面实例所示:

  1. <h1>我是标题1 h1. <small>我是副标题1 h1</small></h1>
  2. <h2>我是标题2 h2. <small>我是副标题2 h2</small></h2>
  3. <h3>我是标题3 h3. <small>我是副标题3 h3</small></h3>
  4. <h4>我是标题4 h4. <small>我是副标题4 h4</small></h4>
  5. <h5>我是标题5 h5. <small>我是副标题5 h5</small></h5>
  6. <h6>我是标题6 h6. <small>我是副标题6 h6</small></h6>
复制代码

  • 页面主体:Bootstrap 将全局 font-size 设置为 14px,line-height 设置为 1.428。这些属性直接赋予 元素和所有段落元素。另外,

    (段落)元素还被设置了等于 1/2 行高(即 10px)的底部外边距(margin)。

  1. <h2>引导主体副本</h2>
  2. <p class="lead">这是一个演示引导主体副本用法的实例。这是一个演示引导主体副本用法的实例。这是一个演示引导主体副本用法的实例。这是一个演示引导主体副本用法的实例。这是一个演示引导主体副本用法的实例。这是一个演示引导主体副本用法的实例。这是一个演示引导主体副本用法的实例。这是一个演示引导主体副本用法的实例。</p>
复制代码

列表:

Bootstrap 支持有序列表、无序列表和定义列表。

  • 有序列表:有序列表是指以数字或其他有序字符开头的列表。
  • 无序列表:无序列表是指没有特定顺序的列表,是以传统风格的着重号开头的列表。如果您不想显示这些着重号,您可以使用 class .list-unstyled 来移除样式。您也可以通过使用 class .list-inline 把所有的列表项放在同一行中。
  • 定义列表:在这种类型的列表中,每个列表项可以包含
    元素。
    代表 定义术语,就像字典,这是被定义的属于(或短语)。接着,
    的描述。您可以使用 class dl-horizontal
    行中的属于与描述并排显示。

下面的实例演示了这些类型的列表:

  1. <h4>有序列表</h4>
  2. <ol>
  3. <li>Item 1</li>
  4. <li>Item 2</li>
  5. <li>Item 3</li>
  6. <li>Item 4</li>
  7. </ol>
  8. <h4>无序列表</h4>
  9. <ul>
  10. <li>Item 1</li>
  11. <li>Item 2</li>
  12. <li>Item 3</li>
  13. <li>Item 4</li>
  14. </ul>
  15. <h4>未定义样式列表</h4>
  16. <ul class="list-unstyled">
  17. <li>Item 1</li>
  18. <li>Item 2</li>
  19. <li>Item 3</li>
  20. <li>Item 4</li>
  21. </ul>
  22. <h4>内联列表</h4>
  23. <ul class="list-inline">
  24. <li>Item 1</li>
  25. <li>Item 2</li>
  26. <li>Item 3</li>
  27. <li>Item 4</li>
  28. </ul>
  29. <h4>定义列表</h4>
  30. <dl>
  31. <dt>Description 1</dt>
  32. <dd>Item 1</dd>
  33. <dt>Description 2</dt>
  34. <dd>Item 2</dd>
  35. </dl>
  36. <h4>水平的定义列表</h4>
  37. <dl class="dl-horizontal">
  38. <dt>Description 1</dt>
  39. <dd>Item 1</dd>
  40. <dt>Description 2</dt>
  41. <dd>Item 2</dd>
  42. </dl>
复制代码

下表提供了 Bootstrap 更多排版类的实例:

三、Bootstrap 代码

Bootstrap 允许您以两种方式显示代码:

  • 第一种是 标签。如果您想要内联显示代码,那么您应该使用 标签。
  1. For example, <code>&lt;section&gt;</code> should be wrapped as inline.
复制代码

  • 第二种是
     标签。如果代码需要被显示为一个独立的块元素或者代码有多行,那么您应该使用 
     标签。
  1. <pre>&lt;p&gt;Sample text here...&lt;/p&gt;</pre>
复制代码

还可以使用 .pre-scrollable 类,其作用是设置 max-height 为 350px ,并在垂直方向展示滚动条。

四、Bootstrap 表格

  • Bootstrap 支持的一些表格元素:

  • 用于表格的样式

  • 用于表格的行或者单元格

基本实例
  • 为任意 标签添加 .table 类可以为其赋予基本的样式 — 少量的内补(padding)和水平方向的分隔线。这种方式看起来很多余!?但是我们觉得,表格元素使用的很广泛,如果我们为其赋予默认样式可能会影响例如日历和日期选择之类的插件,所以我们选择将此样式独立出来。
    1. <table class="table">
    2. <caption>基本的表格布局</caption>
    3. <thead>
    4. <tr>
    5. <th>名称</th>
    6. <th>城市</th>
    7. </tr>
    8. </thead>
    9. <tbody>
    10. <tr>
    11. <td>Tanmay</td>
    12. <td>Bangalore</td>
    13. </tr>
    14. <tr>
    15. <td>Sachin</td>
    16. <td>Mumbai</td>
    17. </tr>
    18. </tbody>
    19. </table>
    复制代码

    • 条纹表格

        通过添加 .table-striped class,您将在

    内的行上看到条纹,如下面的实例所示:

    1. <table class="table table-striped">
    2. <caption>条纹表格布局</caption>
    3. <thead>
    4. <tr>
    5. <th>名称</th>
    6. <th>城市</th>
    7. <th>邮编</th>
    8. </tr>
    9. </thead>
    10. <tbody>
    11. <tr>
    12. <td>Tanmay</td>
    13. <td>Bangalore</td>
    14. <td>560001</td>
    15. </tr>
    16. <tr>
    17. <td>Sachin</td>
    18. <td>Mumbai</td>
    19. <td>400003</td>
    20. </tr>
    21. <tr>
    22. <td>Uma</td>
    23. <td>Pune</td>
    24. <td>411027</td>
    25. </tr>
    26. </tbody>
    27. </table>
    复制代码

    • 带边框的表格

        通过添加 .table-bordered class,您将看到每个元素周围都有边框,且占整个表格是圆角的,如下面的实例所示:

    1. <table class="table table-bordered">
    2. <caption>边框表格布局</caption>
    3. <thead>
    4. <tr>
    5. <th>名称</th>
    6. <th>城市</th>
    7. <th>邮编</th>
    8. </tr>
    9. </thead>
    10. <tbody>
    11. <tr>
    12. <td>Tanmay</td>
    13. <td>Bangalore</td>
    14. <td>560001</td>
    15. </tr>
    16. <tr>
    17. <td>Sachin</td>
    18. <td>Mumbai</td>
    19. <td>400003</td>
    20. </tr>
    21. <tr>
    22. <td>Uma</td>
    23. <td>Pune</td>
    24. <td>411027</td>
    25. </tr>
    26. </tbody>
    27. </table>
    复制代码

    • 悬停表格

        通过添加 .table-hover class,当指针悬停在行上时会出现浅灰色背景,如下面的实例所示:

    1. <table class="table table-hover">
    2. <caption>悬停表格布局</caption>
    3. <thead>
    4. <tr>
    5. <th>名称</th>
    6. <th>城市</th>
    7. <th>邮编</th>
    8. </tr>
    9. </thead>
    10. <tbody>
    11. <tr>
    12. <td>Tanmay</td>
    13. <td>Bangalore</td>
    14. <td>560001</td>
    15. </tr>
    16. <tr>
    17. <td>Sachin</td>
    18. <td>Mumbai</td>
    19. <td>400003</td>
    20. </tr>
    21. <tr>
    22. <td>Uma</td>
    23. <td>Pune</td>
    24. <td>411027</td>
    25. </tr>
    26. </tbody>
    27. </table>
    复制代码

    • 精简表格

        通过添加 .table-condensed class,行内边距(padding)被切为两半,以便让表看起来更紧凑,如下面的实例所示。这在想让信息看起来更紧凑时非常有用。

    1. <table class="table table-condensed">
    2. <caption>精简表格布局</caption>
    3. <thead>
    4. <tr>
    5. <th>名称</th>
    6. <th>城市</th>
    7. <th>邮编</th></tr>
    8. </thead>
    9. <tbody>
    10. <tr>
    11. <td>Tanmay</td>
    12. <td>Bangalore</td>
    13. <td>560001</td></tr>
    14. <tr>
    15. <td>Sachin</td>
    16. <td>Mumbai</td>
    17. <td>400003</td></tr>
    18. <tr>
    19. <td>Uma</td>
    20. <td>Pune</td>
    21. <td>411027</td></tr>
    22. </tbody>
    23. </table>
    复制代码

    • 上下文类

        下表中所列出的上下文类允许您改变表格行或单个单元格的背景颜色。

    1. <table class="table">
    2. <caption>上下文表格布局</caption>
    3. <thead>
    4. <tr>
    5. <th>产品</th>
    6. <th>付款日期</th>
    7. <th>状态</th></tr>
    8. </thead>
    9. <tbody>
    10. <tr class="active">
    11. <td>产品1</td>
    12. <td>23/11/2013</td>
    13. <td>待发货</td></tr>
    14. <tr class="success">
    15. <td>产品2</td>
    16. <td>10/11/2013</td>
    17. <td>发货中</td></tr>
    18. <tr class="warning">
    19. <td>产品3</td>
    20. <td>20/10/2013</td>
    21. <td>待确认</td></tr>
    22. <tr class="danger">
    23. <td>产品4</td>
    24. <td>20/10/2013</td>
    25. <td>已退货</td></tr>
    26. </tbody>
    27. </table>
    复制代码

    • 响应式表格

        通过把任意的 .table 包在 .table-responsive class 内,您可以让表格水平滚动以适应小型设备(小于 768px)。当在大于 768px 宽的大型设备上查看时,您将看不到任何的差别。

    1. <div class="table-responsive">
    2. <table class="table">
    3. <caption>响应式表格布局</caption>
    4. <thead>
    5. <tr>
    6. <th>产品</th>
    7. <th>付款日期</th>
    8. <th>状态</th></tr>
    9. </thead>
    10. <tbody>
    11. <tr>
    12. <td>产品1</td>
    13. <td>23/11/2013</td>
    14. <td>待发货</td></tr>
    15. <tr>
    16. <td>产品2</td>
    17. <td>10/11/2013</td>
    18. <td>发货中</td></tr>
    19. <tr>
    20. <td>产品3</td>
    21. <td>20/10/2013</td>
    22. <td>待确认</td></tr>
    23. <tr>
    24. <td>产品4</td>
    25. <td>20/10/2013</td>
    26. <td>已退货</td></tr>
    27. </tbody>
    28. </table>
    29. </div>
    复制代码

    五、Bootstrap 表单
    • 基本的表单结构是 Bootstrap 自带的,个别的表单控件自动接收一些全局样式。下面列出了创建基本表单的步骤:

      • 向父
        元素添加 role="form"
      • 把标签和控件放在一个带有 class .form-group
        中。这是获取最佳间距所必需的。
      • 向所有的文本元素