PC端/移动端不同?
PC端
屏幕大,网页固定版心
端浏览器繁多,更多考虑兼容性问题。(布局: 浮动+定位+标准流)
移动端
手机屏幕小,网页宽度多数为100%,是适配手机屏幕宽度
移动端则基本不需要考虑兼容性问题,放心大胆使用CSS新特性
物理分辨率和逻辑分辨率
物理分辨率:硬件所支持的,屏幕出厂就设定无法修改
逻辑分辨率:软件可以达到的, 我们开发中写的是逻辑分辨率
视口
视口(viewport)就是浏览器显示页面内容的屏幕区域。
视口的分类:
布局视口 。 iOS, Android基本都将这个视口分辨率设置为980px。
视觉视口。用户正在看到的网站的区域。
理想视口。 设备有多宽,我的网页就显示有多宽
视口标签
有了视口标签,可以达到我们想要的理想视口。
二倍图
其实实际开发中还有三倍图甚至四倍图等,多倍图,但是现在市场还是二倍图偏多,我们称为二倍图。
简单理解,二倍图存在就是为了让页面中图片更加清晰,遵循即可。
网页美工的设计稿基本是 750px
我们前端工程师拿到设计稿利用像素大厨选择 2X, 进行缩小一半,按照提示的单位开发即可。
flex布局
flex布局极大的提高了我们布局的效率,更简单、灵活。
display: flex; 一定要给亲爸爸加。
justify-content:;在此属性后添加主轴对齐方式 加在父盒子身上
主轴布局方式
属性值 作用
flex-start 默认值, 起点开始依次排列
flex-end 终点开始依次排列
center 沿主轴居中排列
space-around 弹性盒子沿主轴均匀排列, 空白间距均分在弹性盒子两侧
space-between 弹性盒子沿主轴均匀排列, 空白间距均分在相邻盒子之间
space-evenly 弹性盒子沿主轴均匀排列, 弹性盒子与容器之间间距相等
侧轴对齐方式:
align-items:;在此属性后加属性值
属性值 作用
flex-start 起点开始依次排列
flex-end 终点开始依次排列
center 沿侧轴居中排列
stretch 默认效果, 弹性盒子沿着侧轴线被拉伸至铺满容器
记忆:
1.两侧没缝隙是 between
2.缝隙一样大是 evenly
3.2倍缝隙是 around
可以通过flex布局让子盒子在父盒子中垂直水平居中
.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;
例:比如有一个父盒子里面有三个子盒子,每个子盒子写 flex:1; 此时每个子盒子各占三分之一。
.father {
display: flex;
height: 300px;
background-color: pink;
}
.father div {
/* 每个孩子各占1份 /
flex: 1;
/ 默认子盒子和父亲一样高 */
background: purple;
}
圣杯布局:
所谓的圣杯布局就是左右两边大小固定不变,中间宽度自适应。
一般这种布局方式适用于各种移动端顶部搜索部分,这是最常见的,如京东手机版主页面顶部搜索
核心思路:
两侧盒子写固定大小
中间盒子 flex: 1; 占满剩余空间
注意:中间flex: 1; 和 width 有冲突。 优先执行 flex:1;
1.在flex眼中,标签不再分类。
简单说就是没有块级元素,行内元素和行内块元素
任何一个元素都可以直接给宽度和高度一行显示
2.Flex不存在脱标的情况:也就是基本淘汰了浮动,更不用清除浮动
3.考虑兼容性问题