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