五一前端专题二-响应式布局

2020-05-03  本文已影响0人  TinkleJane

常用解决方案

px和视口

px是一个相对单位,相对的是设备像素(device pixel)。

理想视口或者应该全称为“理想的布局视口”,在移动设备中就是指设备的分辨率。换句话说,理想视口或者说分辨率就是给定设备物理像素的情况下,最佳的“布局视口”。
1 CSS像素 = 物理像素/分辨率

媒体查询

媒体查询是向不同设备提供不同样式的一种方式,它为每种类型的用户提供了最佳的体验。
一套样式不行,给每一种设备各一套不同的样式

用法

  1. link标签引入
    media属性(eg:引入(screen)彩色屏幕显示,并且最大宽度不超过800px时候的CSS样式)
<link rel="stylesheet" media="screen and (max-width:800px)" href="./demo.css">
  1. style中直接引入
@media print { ... }
@media screen, print { ... }
@media (max-width: 12450px) { ... }
@media screen and (min-width: 30em) and (orientation: landscape) { ... }

百分比

百分比单位缺点
(1)计算困难,如果我们要定义一个元素的宽度和高度,按照设计稿,必须换算成百分比单位。
(2)各个属性中如果使用百分比,相对父元素的属性并不是唯一的。比如width和height相对于父元素的width和height,而margin、padding不管垂直还是水平方向都相对比父元素的宽度、border-radius则是相对于元素自身等等,造成我们使用百分比单位容易使布局问题变得复杂。

自适应场景下的rem解决方案

与em单位不同,rem单位无论嵌套层级如何,都只相对于浏览器的根元素(HTML元素)的font-size。默认情况下,html元素的font-size为16px.

通过vw/vh来实现自适应

主要原理是两个等式
1)100vw = 屏幕物理宽度(750px-设计图宽度)=> 100/750 = 0.1333333vw = 1px
2)1rem = 1html字体大小 >= 12px(font-size最小值是12px)
1px = 0.1333333vw => 12px = 1.6vw => 40px = 40*0.1333333vw = 5.3333vw
结论:5.3333vw = 40px (设计图)
设置 html{ font-size: 5.3333vw; }
则:因为1 rem = 40 px(设计图) 所以 48px(设计图) = 48/40rem = 1.2rem

参考

响应式布局的常用解决方案对比-Github
使用媒体查询-MDN
CSS3之媒体查询(响应式布局)-CSDN

上一篇 下一篇

猜你喜欢

热点阅读