移動端rem適配佈局

dome以下:css

<!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';
    };html

    // 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>app

 

使用說明: 拿到320的設計圖按照標註尺寸大小除以100,便可獲得rem值,若是是640的設計圖則除以200,便可獲得rem值;dom

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

      你能夠把上面的dome拷下來,完了本身改動改動 上述代碼中的 320 和100 兩個值試試,佈局

      前者是換算比,後者是設計圖尺寸;字體

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

 css 裏面一些好的東西:spa

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

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

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

 

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

相關文章
相關標籤/搜索