移动端布局方案汇总&&原理解析
程序员文章站
2022-07-02 16:44:37
阿里flexible布局 版本1.x 该布局于 2017年8月9日被2.0版本取代 实现原理 设置viewport的 将屏幕分成10份, 开发时直接填写 利用 转换为 实际rem 阿里flexible布局 版本2.x flexible 2.x: https://github.com/amfe/lib ......
阿里flexible布局 - 版本1.x
该布局于 2017年8月9日被2.0版本取代
实现原理 假设(ui稿750px宽)
- 设置viewport的
scale = 1/window.devicepixelratio
- 将屏幕分成10份,
font-size = 实际屏幕宽度 / 10;
- 开发时直接填写
(设计稿dom宽度)px
- 利用
px2rem插件
转换为 -> 实际rem
阿里flexible布局 - 版本2.x
flexible 2.x:
实现原理
- 利用viewport的理想视口,删除1.x版本的scale缩放
- 其他依旧和1.x版本一样
网易布局
个人很喜欢的布局方案
实现原理 假设(ui稿750px宽)
- 如低版本浏览器:
- ui稿以
font-size = 100px;
作为参照,总宽度 = 7.5rem
-
设计稿dom对应px / 100 = 实际rem
(计算起来很方便) - 其他屏幕按
屏幕宽度百分比 缩放 font-size的值
- ui稿以
- 若高版本浏览器:
1px/750px ≈ 0.1333333%
- 按照低版本逻辑:
font-size = 0.1333333% * 100 = 13.33333vw
webpack插件postcss-px-to-viewport
顾名思义,将px转换为vw、vh、vmin、vmax
{ viewportwidth: 750, viewportheight: 1334, unitprecision: 3, viewportunit: 'vw', selectorblacklist: ['.ignore', '.hairlines'], minpixelvalue: 1, mediaquery: false }
end
上一篇: C#读写EXCEL单元格的问题
下一篇: day11