移动端布局方案汇总&&原理解析

阿里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: github.com/amfe/lib-fl…

实现原理

  • 利用viewport的理想视口,删除1.x版本的scale缩放
  • 其他依旧和1.x版本一样

网易布局

个人很喜欢的布局方案

实现原理 假设(UI稿750px宽)

  • 如低版本浏览器:
    • UI稿以font-size = 100px;作为参照,总宽度 = 7.5rem
    • 设计稿DOM对应px / 100 = 实际rem(计算起来很方便)
    • 其他屏幕按屏幕宽度百分比 缩放 font-size的值
  • 若高版本浏览器:
    • 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

文章分享同步于: github.com/zhongmeizhi…

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值