移動端rem適配布局


dome如下:

<!doctype html>
<html>
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
<title>移動h5自適應布局</title>
<style>
  /*320px布局*/
  html{font-size: 100px;}
  body{font-size: 0.14rem;/*實際相當於14px*/}
  body{
    padding:0;
    margin:0;
  }
  .div2{
    font-size:0.14rem;
  }
  .div3{
    width:3rem;
    height:3rem;
    border:1px solid #000;
    box-sizing:border-box;
  }
  .div4{
    margin-top:0.1rem;
    width:2rem;
    height:2rem;
    border:1px solid #000;
    box-sizing:border-box;
  }
  .img1{
    width:3.2rem;
  }
</style>
</head>
<body>
  <div class="div2">動態更改html元素大小</div>
  <div class="div3"></div>
  <div class="div4"></div>
  <img class="img1" src="http://www.baidu.com/img/bdlogo.png" alt="" />
</body>
<script>
  // 該代碼來自http://www.ghugo.com/mobile-h5-fluid-layout-for-iphone6/
(function (doc, win) {
    // 分辨率Resolution適配
    var docEl = doc.documentElement,
    resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize',
    recalc = function () {
      var clientWidth = docEl.clientWidth;
      if (!clientWidth) return;
      docEl.style.fontSize = 100 * (clientWidth / 320) + 'px';
    };

    // Abort if browser does not support addEventListener
    if (!doc.addEventListener) return;
    win.addEventListener(resizeEvt, recalc, false);
    doc.addEventListener('DOMContentLoaded', recalc, false);
    // 一物理像素在不同屏幕的顯示效果不一樣。要根據devicePixelRatio來修改meta標簽的scale,要注釋上面的meta標簽
    (function(){
      return;
      var dpr = scale =1;
      var isIPhone = win.navigator.appVersion.match(/iphone/gi);
      var devicePixelRatio = win.devicePixelRatio;
      if (isIPhone) {
        // iOS下,對於2和3的屏,用2倍的方案,其余的用1倍方案
      if (devicePixelRatio >= 3 && (!dpr || dpr >= 3)) {
        dpr = 3;
      } else if (devicePixelRatio >= 2 && (!dpr || dpr >= 2)){
        dpr = 2;
      } else {
        dpr = 1;
      }
    } else {
    // 其他設備下,仍舊使用1倍的方案
      dpr = 1;
    }
      scale = 1 / dpr;

//
    var metaEl = "";
    metaEl = doc.createElement('meta');
    metaEl.setAttribute('name', 'viewport');
    metaEl.setAttribute('content', 'initial-scale=' + scale + ', maximum-scale=' + scale + ', minimum-scale=' + scale + ', user-scalable=no');
    if (docEl.firstElementChild) {
      docEl.firstElementChild.appendChild(metaEl);
    } else {
      var wrap = doc.createElement('div');
      wrap.appendChild(metaEl);
      doc.write(wrap.innerHTML);
    }
  })();
})(document, window);
</script>
</html>

 

使用說明: 拿到320的設計圖按照標注尺寸大小除以100,即可得到rem值,如果是640的設計圖則除以200,即可得到rem值;

      docEl.style.fontSize = 100 * (clientWidth / 320) + 'px';

      你可以把上面的dome拷下來,完了自己改動改動 上述代碼中的 320 和100 兩個值試試,

      前者是換算比,后者是設計圖尺寸;

       要用的話就把這個js拷下來,作為一個單獨的js插件引入到你的html中,按着比例換算即可

 css 里面一些好的東西:

      字體不換行 -  white-space:nowrap;

      超出部分以省略號顯示 -  text-overflow:ellipsis; 配合 overflow: hidden;使用

      字體和圖片在一行的時候字體和圖片居中對接   -   vertical-align:middle;

 

 原文獻:http://www.cnblogs.com/samwu/p/4285748.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM