从前慢-移动Web开发之响应式布局

Posted Java大世界

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了从前慢-移动Web开发之响应式布局相关的知识,希望对你有一定的参考价值。

前言

想要获取该该课程markdown笔记(脑图+笔记)。
搜索微信公众号-Java大世界。回复响应式,即可
获取笔记获取方式。

移动Web开发之响应式布局

1.1 响应式布局

就是使用媒体查询针对不同宽度的设备进行布局和样式的设置,
从而适配不同设备的目的。

1.1.1 设备的划分情况:

小于768的为超小屏幕(手机)
768~992之间的为小屏设备(平板)
992~1200的中等屏幕(桌面显示器)
大于1200的宽屏设备(大桌面显示器)

1.1.2 响应式开发

响应式布局容器
响应式需要一个父级做为布局容器,来配合子级元素来实现变化效果。
原理就是在不同屏幕下,通过媒体查询来改变这个布局容器的大小,
再改变里面子元素的排列方式和大小,从而实现不同屏幕下,看到
不同的页面布局和样式变化。

超小屏幕(手机,小于 768px):设置宽度为 100%
小屏幕(平板,大于等于 768px):设置宽度为 750px
中等屏幕(桌面显示器,大于等于 992px):宽度设置为 970px
大屏幕(大桌面显示器,大于等于 1200px):宽度设置为 1170px
<!DOCTYPE html>
<html lang="en">

<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<style>
.container {
height: 150px;
background-color: pink;
margin: 0 auto;
}
/* 1. 超小屏幕下 小于 768 布局容器的宽度为 100% */

@media screen and (max-width: 767px) {
.container {
width: 100%;
}
}
/* 2. 小屏幕下 大于等于768 布局容器改为 750px */

@media screen and (min-width: 768px) {
.container {
width: 750px;
}
}
/* 3. 中等屏幕下 大于等于 992px 布局容器修改为 970px */

@media screen and (min-width: 992px) {
.container {
width: 970px;
}
}
/* 4. 大屏幕下 大于等于1200 布局容器修改为 1170 */

@media screen and (min-width: 1200px) {
.container {
width: 1170px;
}
}
</style>
</head>

<body>
<!-- 响应式开发里面,首先需要一个布局容器 -->
<div class="container"></div>
</body>

</html>

1.1.3 响应式导航

1 当我们屏幕大于等于800像素,我们给nav宽度为800px,因
为里面子盒子需要浮动,所以nav需要清除浮动。
2 nav里面包含8个小li 盒子,每个盒子的宽度定为 100px, 高
度为 30px,浮动一行显示。
3 当我们屏幕缩放,宽度小于800像素的时候, nav盒子宽度修
改为 100% 宽度。
nav里面的8个小li,宽度修改为 33.33%,这样一行就只能显示
3个小li ,剩余下行显示。
<!DOCTYPE html>
<html lang="en">

<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<style>
* {
margin: 0;
padding: 0;
}

ul {
list-style: none;
}

.container {
width: 750px;
margin: 0 auto;
}

.container ul li {
float: left;
width: 93.75px;
height: 30px;
background-color: green;
}

@media screen and (max-width: 767px) {
.container {
width: 100%;
}
.container ul li {
width: 33.33%;
}
}
</style>
</head>

<body>
<div class="container">
<ul>
<li>导航栏</li>
<li>导航栏</li>
<li>导航栏</li>
<li>导航栏</li>
<li>导航栏</li>
<li>导航栏</li>
<li>导航栏</li>
<li>导航栏</li>
</ul>
</div>
</body>

</html>

1.2 bootstrap的介绍

1.2.1 创建html骨架结构

<!--要求当前网页使用IE浏览器最高版本的内核来渲染-->
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<!--视口的设置:视口的宽度和设备一致,默认的缩放比例和PC端一致,用户不能自行缩放-->
<meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=0">
<!--[if lt IE 9]>
<!--解决ie9以下浏览器对html5新增标签的不识别,并导致CSS不起作用的问题-->

<script src="https://oss.maxcdn.com/html5shiv/3.7.2/html5shiv.min.js"></script>
<!--解决ie9以下浏览器对 css3 Media Query 的不识别 -->
<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script>
<![endif]-->

1.2.2 引入相关样式文件

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

1.2.3 栅格系统使用

<!DOCTYPE html>
<html lang="en">

<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<!--[if lt IE 9]>
<script ></script>
<script ></script>
<![endif]-->

<!-- 一定不要忘记引入bootstrap 的样式文件 -->
<link rel="stylesheet" href="bootstrap/css/bootstrap.min.css">
<title>Document</title>
<style>
[class^="col"] {
border: 1px solid #ccc;
}

.row:nth-child(1) {
background-color: pink;
}
</style>
</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">4</div>
</div>
<!-- 如果孩子的份数相加等于12 则孩子能占满整个 的container 的宽度 -->
<div class="row">
<div class="col-lg-6">1</div>
<div class="col-lg-2">2</div>
<div class="col-lg-2">3</div>
<div class="col-lg-2">4</div>
</div>
<!-- 如果孩子的份数相加 小于 12 则会?则占不满整个container 的宽度 会有空白 -->
<div class="row">
<div class="col-lg-6">1</div>
<div class="col-lg-2">2</div>
<div class="col-lg-2">3</div>
<div class="col-lg-1">4</div>
</div>
<!-- 如果孩子的份数相加 大于 12 则会?多于的那一列会 另起一行显示 -->

<div class="row">
<div class="col-lg-6">1</div>
<div class="col-lg-2">2</div>
<div class="col-lg-2">3</div>
<div class="col-lg-3">4</div>
</div>

</div>
</body>

</html>

1.2.4 布局容器

Bootstrap 需要为页面内容和栅格系统包裹一个 .container 容
器,它提供了两个作此用处的类
1. container 类
响应式布局的容器 固定宽度
大屏 ( >=1200px) 宽度定为 1170px
中屏 ( >=992px) 宽度定为 970px
小屏 ( >=768px) 宽度定为 750px
超小屏 (100%)
2. container-fluid 类
流式布局容器 百分百宽度
占据全部视口(viewport)的容器。
该文章篇幅太大,想了解更多,点击阅读原文即可!
可能会出现微信没有相应,点击等待即可。


以上是关于从前慢-移动Web开发之响应式布局的主要内容,如果未能解决你的问题,请参考以下文章

从前慢-移动WEB开发之rem适配布局

移动WEB开发之响应式布局

移动端WEB开发之响应式布局

移动WEB开发之响应式布局

移动WEB开发之响应式布局

四十二移动端web开发之响应式布局