专栏名称: Haley的空间
前端
目录
相关文章推荐
上海市司法局  ·  依靠AI生成的内容,能够随心使用吗? ·  23 小时前  
阜阳新闻综合频道  ·  歌手周深,传来喜讯! ·  2 天前  
阜阳新闻综合频道  ·  歌手周深,传来喜讯! ·  2 天前  
最高人民检察院  ·  扛起“家本故里”的职责使命 ·  2 天前  
最高人民检察院  ·  第九届全国检察“三微”优秀作品展播|微电影: ... ·  3 天前  
51好读  ›  专栏  ›  Haley的空间

移动端前端适配方案对比

Haley的空间  · 掘金  ·  · 2018-01-02 05:49

正文

最近抽空看了看移动端适配的一些文章,也结合自己的经验做一下总结以及对比。

那么,开始正题,首先说说到目前位置出现的一些关于移动端适配的技术方案:

  • 通过媒体查询的方式即 CSS3 meida queries
  • 以天猫首页为代表的 flex 弹性布局
  • 以淘宝首页为代表的 rem + viewport 缩放
  • rem 方式

Meida Queries

meida queries 的方式可以说是我早期采用的布局方式,它主要是通过查询设备的宽度来执行不同的 css 代码,最终达到界面的配置。核心语法是:

@media screen and (max-width: 600px) { /*当屏幕尺寸小于600px时,应用下面的CSS样式*/
  /*你的css代码*/
}

!Meida Queries

优点

  • media query 可以做到设备像素比的判断,方法简单,成本低,特别是对移动和PC维护同一套代码的时候。目前像 Bootstrap 等框架使用这种方式布局
  • 图片便于修改,只需修改css文件
  • 调整屏幕宽度的时候不用刷新页面即可响应式展示

缺点

  • 代码量比较大,维护不方便
  • 为了兼顾大屏幕或高清设备,会造成其他设备资源浪费,特别是加载图片资源
  • 为了兼顾移动端和PC端各自响应式的展示效果,难免会损失各自特有的交互方式

Flex 弹性布局

以天猫的实现方式进行说明:

它的 viewport 是固定的: <meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no">

!Flex

高度定死,宽度自适应,元素都采用 px 做单位。

随着屏幕宽度变化,页面也会跟着变化,效果就和PC页面的流体布局差不多,在哪个宽度需要调整的时候使用响应式布局调调就行(比如网易新闻),这样就实现了『适配』。 DEMO>>

rem + viewport 缩放

这也是淘宝使用的方案,根据屏幕宽度设定 rem 值,需要适配的元素都使用 rem 为单位,不需要适配的元素还是使用 px 为单位。

实现原理

根据 rem 将页面放大 dpr 倍, 然后 viewport 设置为 1/dpr .

  • 如iphone6 plus的dpr为3, 则页面整体放大3倍, 1px(css单位)在plus下默认为3px(物理像素)
  • 然后 viewport 设置为1/3, 这样页面整体缩回原始大小. 从而实现高清。

!viewport

!viewport

这样整个网页在设备内显示时的页面宽度就会等于设备逻辑像素大小,也就是 device-width 。这个 device-width 的计算公式为:

设备的物理分辨率/(devicePixelRatio * scale) ,在 scale 为1的情况下, device-width = 设备的物理分辨率/devicePixelRatio

具体请查看 github.com/amfe/lib-fl… www.npmjs.com/package/ani… .

rem 实现

说说我司【魅族】移动端的实现方式, viewport 也是固定的: <meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no">

通过以下代码来控制 rem 基准值(设计稿以 720px 宽度量取实际尺寸)

!function (d) {
    var c = d.document;
    var a = c.documentElement;
    var b = d.devicePixelRatio;
    var f;
    function e() {
      var h = a.getBoundingClientRect().width, g;
      if (b === 1) {
        h = 720
      }
      if(h>720) h = 720;//设置基准值的极限值
      g                = h / 7.2;
      a.style.fontSize = g + "px"
    }
    if (b > 2) {
      b = 3
    } else {
      if (b > 1) {
        b = 2
      } else {
        b = 1
      }
    }
    a.setAttribute("data-dpr", b);
    d.addEventListener("resize", function () {
      clearTimeout(f);
      f = setTimeout(e, 200)
    }, false);
    e()
  }(window);

css 通过 sass 预编译,设置量取的 px 值转化 rem 的变量 $px: (1/100)+rem; ;

!rem

1像素边框高清

淘宝实现方式

上面说到的淘宝的实现方式即 rem + viewport 缩放来实现。

transform: scale(0.5)

CSS 代码:

div{
    width: 1px;
    height: 100%;
    display: block;
    border-left: 1px solid #e5e5e5;
    -webkit-transform: scaleX(.5);
    transform: scaleX(.5);
}

缺点:







请到「今天看啥」查看全文