美文网首页
五一前端专题二-响应式布局

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

作者: TinkleJane | 来源:发表于2020-05-03 12:15 被阅读0次

常用解决方案

px和视口

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

  • 物理像素
    设备像素,在同一个设备上,它的物理像素是固定的,这是厂商在出厂时就设置好了的,即一个设备的分辨率是固定的。
  • CSS像素
    由于不同的物理设备的物理像素的大小是不一样的,所以css认为浏览器应该对css中的像素进行调节,使得浏览器中 1css像素的大小在不同物理设备上看上去大小总是差不多 ,目的是为了保证阅读体验一致。
    默认情况下一个CSS像素应该是等于一个物理像素的宽度的,但是浏览器的放大操作让一个CSS像素等于了两个设备像素宽度。
  • 视口
    (1) 布局视口(layout viewport),默认为980px。
    (2) 视觉视口(visual viewport)
    视觉视口表示浏览器内看到的网站的显示区域,用户可以通过缩放来查看网页的显示内容,从而改变视觉视口。
    (3) 理想视口(ideal viewport)

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

媒体查询

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

  • 媒体类型(Media Type): all(全部)、screen(屏幕)、print(页面打印或打印预览模式)
  • 媒体特性(Media features): width(渲染区宽度)、device-width(设备宽度)...
  • Media Query是CSS3 对Media Type的增强版,其实可以将Media Query看成Media Type(判断条件)+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

相关文章

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

    常用解决方案 px和视口 px是一个相对单位,相对的是设备像素(device pixel)。 物理像素设备像素,在...

  • web前端开发之几种布局方式之响应式布局

    web前端开发之几种布局方式之响应式布局

  • Bootstrap介绍

    Bootstrap是基于HTML、CSS、JavaScript的前端框架 Bootstrap用于响应式前端布局,移...

  • 前端响应式布局原理与方案(详细版)

    前端响应式布局原理与方案(详细版) 引言 响应式布局指的是同一页面在不同屏幕尺寸下有不同的布局。传统的开发方式是 ...

  • 响应式布局目录

    └─Web响应式布局├─1 响应式布局介绍├─2 响应式布局实例(Media Queries模块) 上├─3 响应...

  • 九、HTML5响应式布局

    @(HTML5)[相应式布局] [TOC] 九、HTML5响应式布局 什么是响应式网页设计(布局) 响应式网页设计...

  • 响应式布局

    一、响应式网页 二、如何测试响应式网页 三、响应式布局必须要清楚的两个概念 四、如何编写响应式网页 五、 Boot...

  • 前端第六天

    前端第六天 目录 补充:z-index flex 布局 响应式布局 过渡及案例 动画 一、z-index 1、代码...

  • 2019-01-24

    前端布局神器display:flex 2009年,W3C提出了一种新的方案--Flex布局,可以简便、完整、响应式...

  • 自适应网页设计(Responsive Web Design)

    什么是自适应? 前端工程师的必备技能如何在不同大小设备上呈现同样的网页。 自适应和响应式的区别 响应式布局 就是一...

网友评论

      本文标题:五一前端专题二-响应式布局

      本文链接:https://www.haomeiwen.com/subject/xoekghtx.html