zoukankan      html  css  js  c++  java
  • rem适配还原设计稿,换算

    假设设计妹妹给我们的设计稿尺寸为 750 * 1500 。结合网易移动端首页html元素上的动态font-size属性、设计稿尺寸、前端与设计之间协作流程一般分为下面两种:

    1、网易做法

    引入:页面开头出引入下面这段代码,用于动态计算font-size

     1 (function(doc, win) {
     2     var docEl = doc.documentElement,
     3         isIOS = navigator.userAgent.match(/(i[^;]+;( U;)? CPU.+Mac OS X/),
     4         dpr = isIOS ? Math.min(win.devicePixelRatio, 3) : 1,
     5         dpr = window.top === window.self ? dpr : 1, //被iframe引用时,禁止缩放
     6         dpr = 1,
     7         scale = 1 / dpr,
     8         resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize';
     9     docEl.dataset.dpr = dpr;
    10     var metaEl = doc.createElement('meta');
    11     metaEl.name = 'viewport';
    12     metaEl.content = 'initial-scale=' + scale + ',maximum-scale=' + scale + ', minimum-scale=' + scale;
    13     docEl.firstElementChild.appendChild(metaEl);
    14     var recalc = function() {
    15         var width = docEl.clientWidth;
    16         if (width / dpr > 750) {
    17             width = 750 * dpr;
    18         }
    19         // 乘以100,px : rem = 100 : 1
    20         docEl.style.fontSize = 100 * (width / 750) + 'px';
    21     };
    22     recalc()
    23     if (!doc.addEventListener) return;
    24     win.addEventListener(resizeEvt, recalc, false);
    25 })(document, window);

    使用:

    未引入前:

    body {

       750px;

      height: 640px;

    }

    引入后:除以100并将px换成rem

    body {

       7.5rem;

      height: 6.4rem;

    }

    换算的依据:

    1 // 乘以100,px : rem = 100 : 1
    2 var recalc = function() {
    3     var width = docEl.clientWidth;
    4     if (width / dpr > 750) {
    5         width = 750 * dpr;
    6     }
    7     // 乘以100,px : rem = 100 : 1
    8     docEl.style.fontSize = 100 * (width / 750) + 'px';
    9 };
  • 相关阅读:
    20155322 2016-2017-2 《Java程序设计》第7周学习总结
    高级sed编程
    正则表达式
    实验十二:kvm环境下qemu-kvm创建虚拟机之间的网络配置
    实验十一:了解qemu-kvm的显示选项参数
    实验十:在kvm下创建winxp虚拟机
    实验九:第二个虚拟机的创建(标准选项)
    实验八:kvm环境搭建并创建第一台cirrOS虚拟机
    sed和gawk
    在脚本中添加颜色
  • 原文地址:https://www.cnblogs.com/haishen/p/10884679.html
Copyright © 2011-2022 走看看