零基础Bootstrap学习之路

一、概述:Bootstrap 是一个用于快速开发 Web 应用程序和网站的前端框架。Bootstrap 是基于 HTML、CSS、JAVASCRIPT 的。

二、作为一个前端人,为什么学习Bootstrap?究其原因主要有以下几点:

(1)移动端先行:自 Bootstrap 3 起,框架包含了贯穿于整个库的移动设备优先的样式。

(2)浏览器的选择方面:所有的主流浏览器都支持 Bootstrap。

(3)容易上手:只要您具备 HTML 和 CSS 的基础知识,您就可以开始学习 Bootstrap。

(4)灵活的响应式设计:Bootstrap 的响应式 CSS 能够自适应于台式机、平板电脑和手机。

(5)代码简单优雅,它为开发人员创建接口提供了一个简洁统一的解决方案。它包含了功能强大的内置组件,易于定制。它还提供了基于 Web 的定制。

三、Bootstrap主要包括哪些知识内容你?

1)简单的Bootstrap页面,基本结构,下载压缩包之后,将其解压到任意目录即可看到一下(压缩版)的目录结构:

bootstrap/
├── css/
│   ├── bootstrap.css
│   ├── bootstrap.min.css
│   ├── bootstrap-theme.css
│   └── bootstrap-theme.min.css
├── js/
│   ├── bootstrap.js
│   └── bootstrap.min.js
└── fonts/
    ├── glyphicons-halflings-regular.eot
    ├── glyphicons-halflings-regular.svg
    ├── glyphicons-halflings-regular.ttf
    └── glyphicons-halflings-regular.woff

 

2)全局CSS样式

3)组件

4)Javascript插件

5)及Bootstrap的定制(非学习重点)

四、实例分析详解

1)基本模板,以下是一个最简单的Bootstrap页面了

<!DOCTYPE htm<html lang="zh-cn">  <head>    <meta charset="utf-8">

    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>Bootstrap 101 Template</title>

    <!-- Bootstrap -->
    <link href="css/bootstrap.min.css" rel="stylesheet">

    <!-- HTML5 shim and Respond.js for IE8 support of HTML5 elements and media queries -->
    <!-- WARNING: Respond.js doesn't work if you view the page via file:// -->
    <!--[if lt IE 9]>
      <script src="http://cdn.bootcss.com/html5shiv/3.7.2/html5shiv.min.js"></script>
      <script src="http://cdn.bootcss.com/respond.js/1.4.2/respond.min.js"></script>
    <![endif]-->
  </head>
  <body>
    <h1>你好,世界!</h1>

    <!-- jQuery (necessary for Bootstrap's JavaScript plugins) -->
    <script src="http://cdn.bootcss.com/jquery/1.11.1/jquery.min.js"></script>
    <!-- Include all compiled plugins (below), or include individual files as needed -->
    <script src="js/bootstrap.min.js"></script>
 </body>
</html>
2)

 <!-- 1.设置 字符的编码格式-->

    <meta charset="utf-8">

    <!-- 2.让IE游览器渲染试图,按照edge游览器的方法 -->

    <meta http-equiv="X-UA-Compatible" content="IE=edge">

    <!-- 3.这是vieport 视口 -->

    <!-- <meta name="viewport" content="width=device-width, initial-scale=1"> -->

    <!-- meta:vp -->

 

     <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0">

     <!-- width=device-width 让网页的尺寸等于手机的尺寸

          user-scalable = no; 禁止缩放(不推荐所有页面使用,具体看情况)

          initial-scale = 1;使CSS里面的标签 按照设置的尺寸1:1显示在手机上

 

      -->

3)容器布局、版心

 Bootstrap 需要为页面内容和栅格系统包裹一个 .container 容器。我们提供了两个作此用处的类。注意,由于 padding等属性的原因,这两种 容器类不能互相嵌套。

 .container 类用于固定宽度并支持响应式布局的容器

   .container-fluid 类用于 100% 宽度,占据全部视口(viewport)的容器

4)栅格系统

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

简介

栅格系统用于通过一系列的行(row)与列(column)的组合来创建页面布局,你的内容就可以放入这些创建好的布局中。下面就介绍一下 Bootstrap 栅格系统的工作原理:

1>“行(row)”必须包含在 .container (固定宽度)或 .container-fluid (100% 宽度)中,以便为其赋予合适的排列(aligment)和内补(padding)。

2>通过“行(row)”在水平方向创建一组“列(column)”。

3>你的内容应当放置于“列(column)”内,并且,只有“列(column)”可以作为行(row)”的直接子元素。

4>类似 .row 和 .col-xs-4 这种预定义的类,可以用来快速创建栅格布局。Bootstrap 源码中定义的 mixin 也可以用来创建语义化的布局。

5>通过为“列(column)”设置 padding 属性,从而创建列与列之间的间隔(gutter)。通过为 .row 元素设置负值 margin 从而抵消掉为 .container 元素设置的 padding,也就间   接为“行(row)”所包含的“列(column)”抵消掉了padding

6>如果一“行(row)”中包含了的“列(column)”大于 12,多余的“列(column)”所在的元素将被作为一个整体另起一行排列。

学习者可以研究一些实例,更好的掌握此知识点

5)代码块

可以使用pre标签和.pre-scrollable来给设置相应的最大页面滚动条

6)

基本实例

为任意 <table> 标签添加 .table 类可以为其赋予基本的样式 — 少量的内补(padding)和水平方向的分隔线。这种方式看起来很多余!?但是我们觉得,表格元素使用的很广泛,如果我们为其赋予默认样式可能会影响例如日历和日期选择之类的插件,所以我们选择将此样式独立出来。

其写法如下:

<table class="table">
  ...
</table>
7)带边框的表格
添加.table-bordered类为表格和其中的每个单元格增加边框
<table class="table table-bordered">
  ...
</table>
8)鼠标悬停

通过添加 .table-hover 类可以让 <tbody> 中的每一行对鼠标悬停状态作出响应。

#First NameLast NameUsername
1 Mark Otto @mdo
2 Jacob Thornton @fat
3 Larry the Bird @twitter
Copy
<table class="table table-hover">
  ...
</table>
9)

通过添加 .table-condensed 类可以让表格更加紧凑,单元格中的内补(padding)均会减半。

#First NameLast NameUsername
1 Mark Otto @mdo
2 Jacob Thornton @fat
3 Larry the Bird @twitter
Copy
<table class="table table-condensed">
  ...
</table>
10)状态类

通过这些状态类可以为行或单元格设置颜色。

Class描述
.active 鼠标悬停在行或单元格上时所设置的颜色
.success 标识成功或积极的动作
.info 标识普通的提示信息或动作
.warning 标识警告或需要用户注意
.danger 标识危险或潜在的带来负面影响的动作
    
Copy
<!-- On rows -->
<tr class="active">...</tr>
<tr class="success">...</tr>
<tr class="warning">...</tr>
<tr class="danger">...</tr>
<tr class="info">...</tr>

<!-- On cells (`td` or `th`) -->
<tr>
  <td class="active">...</td>
  <td class="success">...</td>
  <td class="warning">...</td>
  <td class="danger">...</td>
  <td class="info">...</td>
</tr>
11)
基本实例

单独的表单控件会被自动赋予一些全局样式。所有设置了 .form-control 类的 <input><textarea> 和 <select> 元素都将被默认设置宽度属性为 width: 100%;。 将 label 元素和前面提到的控件包裹在 .form-group 中可以获得最好的排列。

Example block-level help text here.

五、组件
1)Gliphicons字体图标
2)下拉菜单

用于显示链接列表的可切换、有上下文的菜单。下拉菜单的Javascript让它具有了交互性。

实例

将下拉菜单触发器和下拉菜单都包裹在 .dropdown 里,或者另一个声明了 position: relative; 的元素。然后加入组成菜单的 HTML 代码。


 
 

 

.

 

 

posted @ 2016-12-14 16:54  陌上辰  阅读(135)  评论(0)    收藏  举报