1.移动端特点
PC端与移动端的不同
PC端的屏幕大,制作页面时需要设置页面的版心
PC端浏览器种类繁多,要考虑更多的兼容性问题 (布局:浮动+定位+标椎流)
移动端的屏幕小,制作时将宽度设大多为100%
移动端基本上不需要考虑兼容性问题,放心大胆使用CSS新特性
(制作移动端页面可以通过谷歌手机模拟器进行调试)
物理分辨率与逻辑分辨率
物理分辨率也就是硬件分辨率,是电脑厂商设置的,默认的电脑分辨率,是不可以修改的
例如:1920 * 1080 1366 * 768 .......
分辨率越高越清晰
逻辑分辨率是软件可以达到的, 我们开发中写的是逻辑分辨率
pc端的物理分辨率与逻辑分辨率是相等的
但是移动端的物理分辨率与逻辑分辨率不完全相同
二倍图
我们写代码是按照逻辑分辨率来写的,以iPhone6/7/8为例,如果IU设计一个375*667的设计稿给我们开发,但是页面放在iPhone6/7/8手机屏幕上显示是750*1334的分辨率,这样就会使得我们的页面失真,所以一般设计师会给我们一个750像素的图,当我们开发时就把设计稿放进像素大厨里将设计稿除以二,给它缩小一倍就可以了.
视口
视口:浏览器显示页面内容的屏幕区域
布局视口
视觉视口
用户正在看到的网站的区域。
理想视口
视口标签
<meta name="viewport" content="width=device-width, initial-scale=1.0,
maximum-scale=1.0, user-scalable=0">
-
width=device-width:视口宽度=设备宽度
-
initial-scale=1.0:初始页面缩放倍数
-
maximum-scale=1.0 最大缩放倍数
-
user-scalable=0 不允许用户缩放页面(移动端) 或者为 no 如果为 yes 则允许用户缩放
2.百分比布局
3.flex布局(弹性布局)
主轴对齐方式
重点记忆justify-content: space-between; 和center
justify-content: space-between;
显示效果两面没有间隙,中间自适应平均分
justify-content: space-around;
效果是中间部分间隙是两边的间隙的两倍
justify-content: space-evenly;
效果是 所有的间隙都是一样宽
justify-content: center;
效果是所用的盒子水平居中
侧轴对齐方式
案例:盒子居中效果
.father {
width: 500px;
height: 500px;
background-color: pink;
/* 设置为flex布局 */
display: flex;
/* 主轴水平居中 */
justify-content: center;
/* 侧轴垂直居中 */
align-items: center;
}
.son {
width: 200px;
height: 200px;
background-color: purple;
}
伸缩比
把父盒子分为若干份数,每个子盒子各占几份。
flex:1; 一定给子盒子加
分配父级剩余的空间
<!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">
<title>Document</title>
<style>
.box {
width: 1200px;
height: 400px;
background-color: pink;
margin: 100px auto;
/* 弹性盒子 */
display: flex;
}
/* 弹性盒子 */
.box>div {
/* 伸缩比,占的是父盒子的宽度,把它分成了等份 */
flex: 1;
margin-right: 15px;
background-color: orange;
}
.box>div:nth-child(2n) {
flex: 2;
background-color: yellowgreen;
}
.box>div:nth-child(4) {
margin-right: 0;
}
</style>
</head>
<body>
<div class="box">
<div>1</div>
<div>2</div>
<div>3</div>
<div>4</div>
</div>
</body>
</html>
圣杯布局
所谓的圣杯布局就是左右两边大小固定不变,中间宽度自适应。
一般这种布局方式适用于各种移动端顶部搜索部分,这是最常见的,如京东手机版主页面顶部搜索
核心思路:
-
两侧盒子写固定大小
-
中间盒子 flex: 1; 占满剩余空间
<!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">
<title>Document</title>
<style>
* {
padding: 0;
margin: 0;
}
.box {
width: 100%;
height: 50px;
background-color: pink;
display: flex;
}
.box .left,
.box .right {
width: 50px;
height: 50px;
background-color:orange;
}
.box .center {
flex: 1;
background-color: purple;
}
</style>
</head>
<body>
<div class="box">
<div class="left"></div>
<div class="center"></div>
<div class="right"></div>
</div>
</body>
</html>
总结:
-
在flex眼中,标签不再分类。
-
简单说就是没有块级元素,行内元素和行内块元素
-
任何一个元素都可以直接给宽度和高度一行显示
-
Flex不存在脱标的情况:也就是基本淘汰了浮动,更不用清除浮动
-
当然存在兼容性问题,如果不考虑兼容性可以大量使用,如果是移动端则不用考虑直接flex