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


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

    实现原理

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

    网易布局

    个人很喜欢的布局方案

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

    • 如低版本浏览器:
      • UI稿以font-size = 100px;作为参照,总宽度 = 7.5rem
      • (设计稿DOM对应px / 750px) * 7.5rem = 实际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

  • 相关阅读:
    vue中使用第三方UI库的移动端rem适配方案
    前端规范--eslint standard
    从上往下打印二叉树
    栈的压入,弹出序列
    随机森林
    LR
    顺时针打印矩阵
    包含min函数的栈
    树的子结构
    合并两个有序链表
  • 原文地址:https://www.cnblogs.com/yangsg/p/10631222.html
Copyright © 2020-2023  润新知