1. 响应式开发原理
1.1 响应式开发原理
- 就是使用媒体查询针对不同宽度的设备进行布局和样式的设置,从而适配不同设备的目的。
- 设备的划分情况:
| 尺寸 | 定义 |
|---|---|
< 768px |
超小屏幕(手机) |
768px~992px |
小屏设备(平板) |
992px~1200px |
中等屏幕(桌面显示器) |
> 1200px |
宽屏设备(大桌面显示器) |
1.2 响应式布局容器
响应式需要一个父级做为布局容器,来配合子级元素来实现变化效果。
原理就是在不同屏幕下,通过媒体查询来改变这个布局容器的大小,再改变里面子元素的排列方式和大小,从而实现不同屏幕下,看到不同的页面布局和样式变化。
父容器版心的尺寸划分:
| 屏幕大小 | 设置宽度 |
|---|---|
超小屏幕(手机,小于 768px) |
设置宽度为 100%
|
小屏幕(平板,大于等于 768px) |
设置宽度为 750px
|
中等屏幕(桌面显示器,大于等于992px) |
宽度设置为 970px
|
大屏幕(大桌面显示器,大于等于 1200px) |
宽度设置为1170px
|
- 但是我们也可以根据实际情况自己定义划分。
2. bootstrap的介绍
2.1 Bootstrap简介
Bootstrap来自 Twitter(推特),是目前最受欢迎的前端框架。Bootstrap是基于HTML、CSS和JAVASCRIPT的,它简洁灵活,使得 Web 开发更加快捷。框架:顾名思义就是一套架构,它有一套比较完整的网页功能解决方案,而且控制权在框架本身,有预制样式库、组件和插件。使用者要按照框架所规定的某种规范进行开发。
2.2 bootstrap 优点
标准化的
html+css编码规范。提供了一套简洁、直观、强悍的组件。
有自己的生态圈,不断的更新迭代。
让开发更简单,提高了开发的效率。
2.3 版本简介
2.x.x:停止维护,兼容性好,代码不够简洁,功能不够完善。3.x.x:目前使用最多,稳定,但是放弃了IE6-IE7。对 IE8 支持但是界面效果不好,偏向用于开发响应式布局、移动设备优先的WEB 项目。4.x.x:最新版,目前还不是很流行。
2.4 bootstrap 基本使用
Bootstrap 使用四步曲:
- 创建文件夹结构

创建文件夹目录
- 创建
html骨架 :
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width,initial-scale=1.0,user-scalable=no"
,maximum-scale=1.0,minimum-scale=1.0>
<!-- 上述3个meta标签*必须*放在最前面,任何其他内容都*必须*跟随其后! -->
<title>BootStrap的使用</title>
<!-- Bootstrap 核心样式-->
<link rel="stylesheet" href="bootstrap/css/bootstrap.min.css">
<!--[if lt IE 9]>
<script src="//cdn.bootcss.com/html5shiv/3.7.2/html5shiv.min.js"></script>
<script src="//cdn.bootcss.com/respond.js/1.4.2/respond.min.js"></script>
<![endif]-->
</head>
<body>
<div class="btn btn-success">成功</div>
<div class="btn btn-danger">危险</div>
</body>
</html>
- 引入相关样式文件 :
<!-- Bootstrap 核心样式-->
<link rel="stylesheet" href="bootstrap/css/bootstrap.min.css">
- 栅格系统的简单使用:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0,user-scalable=no"
,maximum-scale=1.0,minimum-scale=1.0>
<title>栅格系统的使用</title>
<link rel="stylesheet" href="./bootstrap/css/bootstrap.min.css">
<style>
div[class^='col'] {
border: 1px solid #ccc;
}
</style>
</head>
<body>
<div class="container">
<div class="row">
<div class="col-lg-3">1</div>
<div class="col-lg-3">2</div>
<div class="col-lg-3">3</div>
<div class="col-lg-3">4</div>
</div>
<!-- 1. 如果孩子份数相加等于 12 则孩子能占满整个的container的宽度 -->
<!-- 2. 如果孩子的份数相加小于 12 则会占不满整个container的宽度会有空白 -->
<div class="row">
<div class="col-lg-2">1</div>
<div class="col-lg-2">2</div>
<div class="col-lg-2">3</div>
<div class="col-lg-2">4</div>
<div class="col-lg-3">5</div>
</div>
<!-- 3. 如果孩子的分数相加大于 12 多余的一列则会另起一行显示 -->
<div class="row">
<div class="col-lg-3">1</div>
<div class="col-lg-3">2</div>
<div class="col-lg-3">3</div>
<div class="col-lg-3">4</div>
<div class="col-lg-3">5</div>
</div>
</div>
</body>
</html>
2.5 bootstrap 布局容器
1.Bootstrap 需要为页面内容和栅格系统包裹一个.container 或者.container-fluid 容器,它提供了两个作此用处的类。
.container
| 响应式布局的容器 | 固定宽度 |
|---|---|
大屏 ( >=1200px) |
宽度定为 1170px
|
中屏 (>=992px ) |
宽度定为 970px
|
小屏 ( >=768px ) |
宽度定为 750px
|
| 超小屏 | (100%) |
.container-fluid
| 流式布局容器 | 百分百宽度 |
|---|---|
| 占据全部视口 | ( viewport )的容器。 |
2.6 bootstrap 栅格系统
Bootstrap提供了一套响应式、移动设备优先的流式栅格系统,随着屏幕或视口(viewport)尺寸的增加,系统会自动分为最多12列。栅格系统用于通过一系列的行(
row)与列(column)的组合来创建页面布局,你的内容就可以放入这些创建好的布局中。
- 按照不同屏幕划分为
1~12等份。- 行(
row) 可以去除父容器作用15px的边距。xs-extra small:超小;sm-small:小;md-medium:中等;lg-large:大。- 列(
column)大于 12,多余的“列(column)”所在的元素将被作为一个整体另起一行排列。- 每一列默认有左右
15像素的padding。- 可以同时为一列指定多个设备的类名,以便划分不同份数 例如
class="col-md-4 col-sm-6"。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0,user-scalable=no"
,maximum-scale=1.0,minimum-scale=1.0>
<link rel="stylesheet" href="./bootstrap/css/bootstrap.min.css">
<style>
div[class^="col"] {
border: 1px solid #ccc;
}
</style>
<title>不同屏幕下的显示效果</title>
</head>
<body>
<div class="container">
<!-- 这个的意思就是: 大屏幕(>=1200px)每行显示四份 中屏幕 (>=992px) 每行显示 三份 小屏每行显示两列
超小屏 每行显示 1 列
-->
<div class="col-lg-3 col-md-4 col-sm-6 col-xs-12">1</div>
<div class="col-lg-3 col-md-4 col-sm-6 col-xs-12">2</div>
<div class="col-lg-3 col-md-4 col-sm-6 col-xs-12">3</div>
<div class="col-lg-3 col-md-4 col-sm-6 col-xs-12">4</div>
</div>
</body>
</html>

大屏

中屏

小屏

超小屏
2.7 栅格嵌套
- 栅格系统内置的栅格系统将内容再次嵌套。简单理解就是一个列内再分成若干份小列。我们可以通过添加一个新的
.row元素和一系列.col-sm-*元素到已经存在的.col-sm-*元素内。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0,user-scalable=no"
,maximum-scale=1.0,minimum-scale=1.0>
<link rel="stylesheet" href="./bootstrap/css/bootstrap.min.css">
<style>
.row>div{
background-color: pink;
}
</style>
<title>栅格系统的嵌套</title>
</head>
<body>
<div class="container">
<div class="row">
<!-- 列嵌套最好加一个 row -->
<div class="col-lg-3 col-md-4 col-sm-6">
<div class="row">
<div class="col-sm-4 col-xs-6" style="background-color: aqua;">a</div>
<div class="col-sm-8 col-xs-6" style="background-color: purple;">b</div>
</div>
</div>
<!-- 列嵌套最好加一个 row -->
<div class="col-lg-3 col-md-4 col-sm-6">
2
</div>
<!-- 列嵌套最好加一个 row -->
<div class="col-lg-3 col-md-4 col-sm-6">
3
</div>
<!-- 列嵌套最好加一个 row -->
<div class="col-lg-3 col-md-4 col-sm-6">
4
</div>
</div>
</div>
</body>
</html>
2.8 栅格系统的列偏移
- 使用
.col-md-offset-*类可以将列在中屏下向右侧偏移。这些类实际是通过使用 * 选择器为当前元素增加了左侧的边距(margin)。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0,user-scalable=no"
,maximum-scale=1.0,minimum-scale=1.0>
<link rel="stylesheet" href="./bootstrap/css/bootstrap.min.css">
<style>
.row div {
background-color: pink;
}
</style>
<title>栅格系统的列偏移</title>
</head>
<body>
<div class="container">
<div class="row">
<div class="col-lg-3 col-md-4">1</div>
<!-- 在中屏下右侧盒子向右偏移4份 -->
<div class="col-lg-3 col-md-4 col-md-offset-4">2</div>
</div>
<!-- 如果只有一个盒子需要进行居中对齐 col-md-offset-2 这其实就是给盒子添加一个margin值 -->
<div class="col-md-8 col-md-offset-2"></div>
</div>
</body>
</html>
2.9 栅格系统的列排序
- 通过使用 .col-md-push-* 和 .col-md-pull-* 类就可以很容易的改变列(column)的顺序。
<!-- 列排序 -->
<div class="row">
<div class="col-lg-4 col-lg-push-8">左侧</div>
<div class="col-lg-8 col-lg-pull-4">右侧</div>
</div>
3. 响应式工具 hidden-* 和 visible-*
-
为了加快对移动设备友好的页面开发工作,利用媒体查询功能,并使用这些工具类可以方便的针对不同设备展示或隐藏页面内容。
hidden-*
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0,user-scalable=no"
,maximum-scale=1.0,minimum-scale=1.0>
<link rel="stylesheet" href="./bootstrap/css/bootstrap.min.css">
<style>
.row div {
background-color: pink;
}
</style>
<title>栅格系统的响应式工具-显示和隐藏</title>
</head>
<body>
<div class="container">
<div class="row">
<div class="col-lg-3 col-md-4 col-sm-6 col-xs-12">1</div>
<div class="col-lg-3 col-md-4 col-sm-6 col-xs-12">2</div>
<div class="col-lg-3 col-md-4 col-sm-6 col-xs-12">3</div>
<div class="col-lg-3 col-md-4 col-sm-6 col-xs-12 hidden-md">4</div>
</div>
<div class="row">
<div class="col-lg-3 col-md-4 col-sm-6 col-xs-12">
<span class="visible-lg">大屏</span>
</div>
<div class="col-lg-3 col-md-4 col-sm-6 col-xs-12">2</div>
<div class="col-lg-3 col-md-4 col-sm-6 col-xs-12">3</div>
<!-- 表示在中屏的时候将其隐藏 -->
<div class="col-lg-3 col-md-4 col-sm-6 col-xs-12 hidden-md">4</div>
</div>
</div>
</body>
</html>

