zoukankan      html  css  js  c++  java
  • 关于移动端的适配问题

    题外话:还记最早之前接触移动端开发的时候,用的是宽度设置百分比,高度固定的方式;百分比适配应该算是最久远,最容易想到的一种适配方案。但是在不同的分辨率下图片出现拉伸变形,导致用户体验比较差。现统计一下目前的几种移动端的适配方案。

    1、流式布局(百分比适配

          百分比适配是按照设计稿,根据展示元素的大小和位置进行百分比的换算。宽度设置百分比,高度固定,字体大小固定,在只要文字的简单页面的时候,百分比适配还是比较实用的。但是存在图片的复杂一点的页面,小屏和大屏的页面差距有点大,用户体验性相对比较差。

    2、响应式布局(媒体查询@media

        媒体查询是根据屏幕区间,更改html的font-size的大小。

    @media screen and (max- 320px) {
        html{font-size: 14px;}
    }
    @media screen and (min- 321px) and (max- 413px) {
        html{font-size: 16px;}
    }
    @media screen and (min- 414px) and (max- 639px) {
        html{font-size: 17px;}
    }
    @media screen and (min- 640px) {
        html{font-size: 18px;}
    }

    一般大型的网站不会考虑这种方式,因为工作量大,一般都是中小型的门户或者博客类站点会采用响应式的方法从web page到webapp直接一步到位,因为这样可以节约成本,不用再专门为自己的网站做一个webapp的版本。

    这种方式根据不同的分辨率设置不同的样式,冗余代码较多,要做多个分辨率的适配,css代码写的较多。使用成熟的bootstrap框架可接受较多时间。

    3、浏览器的缩放功能

     根据设计稿的还原成HTML,然后根据屏幕宽度除以设计稿的宽度的值在进行设置缩放。

    <meta name="viewport" content="width=320,maximum-scale=2,minimum-scale=2,initial-scale=2,user-scalable=no"> //640

     这种方法在缩放可能会导致有些页面元素会糊的情况,所以不太推荐这种方法

    4、使用rem单位

     rem ------ 是指相对于根元素的字体大小的单位,

         rem值  =  需要转换的像素值 ÷ 根元素html的font-size  

      em ------ 是指相对于父元素的字体大小的单位, 浏览器的默认字体高都是16px,所以未经调整的浏览器1em为16px

        em值  =  需要转换的像素值 ÷ 父元素的font-size 

    html{ font-size: 62.5%}  // 10/16*100%
    h1{font-size: 2rem}   //2*10 = 20px

      根据不同的屏幕大小动态设置html的字体大小font-size,然后rem值换算设置width,height,padding,margin值等。

      可以使用js动态设置html的字体大小和缩放值,如下flexible.js

    !function(e) {
        function t() {
            var t = o.getBoundingClientRect().width;
            t / i > 640 && (t = 640 * i),
            e.rem = t / 10,
            o.style.fontSize = e.rem + "px"
        }
        var i, n, a, r = e.document,
        o = r.documentElement,
        l = r.querySelector('meta[name="viewport"]'),
        d = r.querySelector('meta[name="flexible"]');
        if (l) {
            var s = l.getAttribute("content").match(/initial-scale=(["']?)([d.]+)1?/);
            s && (n = parseFloat(s[2]), i = parseInt(1 / n))
        } else if (d) {
            var s = d.getAttribute("content").match(/initial-dpr=(["']?)([d.]+)1?/);
            s && (i = parseFloat(s[2]), n = parseFloat((1 / i).toFixed(2)))
        }
        if (!i && !n) {
            var m = (e.navigator.appVersion.match(/android/gi), e.navigator.appVersion.match(/iphone/gi)),
            i = e.devicePixelRatio;
            i = m ? i >= 3 ? 3 : i >= 2 ? 2 : 1 : 1,
            n = 1 / i
        }
        if (o.setAttribute("data-dpr", i), !l)
    if (l = r.createElement("meta"), l.setAttribute("name", "viewport"),
    l.setAttribute("content", "initial-scale=" + n + ", maximum-scale=" + n + ", minimum-scale=" + n + ", user-scalable=no"), o.firstElementChild) o.firstElementChild.appendChild(l); else { var c = r.createElement("div"); c.appendChild(l), r.write(c.innerHTML) } e.dpr = i, e.addEventListener("resize", function() { clearTimeout(a), a = setTimeout(t, 300) }, !1), e.addEventListener("pageshow", function(e) { e.persisted && (clearTimeout(a), a = setTimeout(t, 300)) }, !1), "complete" === r.readyState ? r.body.style.fontSize = 12 * i + "px": r.addEventListener("DOMContentLoaded", function() { r.body.style.fontSize = 12 * i + "px" }, !1), t() } (window);

    如果觉得换算比较麻烦,Sublime Text 3安装cssrem插件,可以进行自动换算。

     rem 兼容性:

  • 相关阅读:
    P2018 消息传递[dp]
    P1436 棋盘分割[dp]
    一条线段引发的思考
    浅谈树上差分
    P2680 运输计划[二分+LCA+树上差分]
    P1600 天天爱跑步[桶+LCA+树上差分]
    P4560 [IOI2014]Wall 砖墙
    P1311 选择客栈[模拟]
    P1314 聪明的质监员[二分答案]
    Linux snmp导入MIB库
  • 原文地址:https://www.cnblogs.com/wjmm/p/8205859.html
Copyright © 2011-2022 走看看