js實現rem自動匹配計算font-size的示例
實際開發(fā)過程中,我們經常會被各種寬度,高度計算搞暈。尤其是使用了rem的計算方式,自適應布局難倒一大片程序員。為了解決這類問題,我覺得可以利用js監(jiān)聽屏幕寬度變化來實現更改HTML 根元素font-size的值。
下面是相關JavaScript的實現代碼:
(function (doc, win) {
var docEl = doc.documentElement,
resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize',
recalc = function () {
var clientWidth = docEl.clientWidth;
if (!clientWidth) return;
if(clientWidth>=640){
docEl.style.fontSize = '100px';
}else{
docEl.style.fontSize = 100 * (clientWidth / 640) + 'px';
}
};
if (!doc.addEventListener) return;
win.addEventListener(resizeEvt, recalc, false);
doc.addEventListener('DOMContentLoaded', recalc, false);
})(document, window);
此代碼選640px為基準值,為什么選640呢,
640px的頁面寬度是一個安全的最大寬度,保證了移動端頁面兩邊不會留白。注意這里的px是css邏輯像素,與設備的物理像素是有區(qū)別的。如iPhone 5使用的是Retina視網膜屏幕,使用2px x 2px的 device pixel 代表 1px x 1px 的 css pixel,所以設備像素數為640 x 1136px,而它的CSS邏輯像素數為320 x 568px。
所以當要切移動端的頁面的時候,需要把效果圖寬度等比例縮放到640px。
比如當頁面中某一div的寬度為60,高度為65的時候,就可以直接這樣寫樣式:
{
width:0.6rem;
height:0.65rem
}
瀏覽器的兼容性
rem是CSS3新引進來的一個度量單位,大家心里肯定會覺得心灰意冷呀,擔心瀏覽器的支持情況。其實大家不用害怕,你可能會驚訝,支持的瀏覽器還是蠻多的,比如:Mozilla Firefox 3.6+、Apple Safari 5+、Google Chrome、IE9+和Opera11+。只是可憐的IE6-8無法,你們就把他們當透明了吧,我向來都是如此。
不過使用單位設置字體,可不能完全不考慮IE了,如果你想使用這個REM,但也想兼容IE下的效果,可你可考慮“px”和“rem”一起使用,用"px"來實現IE6-8下的效果,然后使用“Rem”來實現代瀏覽器的效果。就讓IE6-8不能隨文字的改變而改變吧,誰讓這個Ie6-8這么老呢?大家不仿試試,還蠻有意思,說不定這個就是主流的度量單位了。
完整實例代碼:
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0;" name="viewport" />
<meta content="telephone=no" name="format-detection" />
<meta name="format-detection" content="email=no" />
<meta http-equiv="Cache-Control" content="no-cache"/>
<title>響應式布局</title>
<style>
html{font-size: 20px;width: 100%;height: 100%;}
body{margin: 0;padding: 0;}
header,footer{width: 100%;background: #17A578;color: #fff;font-size:1rem;text-align: center;line-height: 2rem;}
.footer{position: fixed;bottom: 0;}
.box{}
.public{width: 5rem;height: 5rem;font-size: 1.2rem;display: inline-block;text-align: center;color: #fff;line-height: 5rem;margin-top: 1rem;}
.left{background: #f00;}
.center{background: #048F74;}
.right{background: #000;}
</style>
</head>
<body>
<header>頁面頭部</header>
<div class="box">
<div class="public left">左</div>
<div class="public center">中</div>
<div class="public right">右</div>
<div class="public left">左</div>
<div class="public center">中</div>
<div class="public right">右</div>
</div>
<footer class="footer">頁面底部</footer>
<script>
//orientationchange方向改變事件
(function (doc, win) {
var docEl = doc.documentElement,//根元素html
//判斷窗口有沒有orientationchange這個方法,有就賦值給一個變量,沒有就返回resize方法。
resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize',
recalc = function () {
var clientWidth = docEl.clientWidth;
if (!clientWidth) return;
//把document的fontSize大小設置成跟窗口成一定比例的大小,從而實現響應式效果。
docEl.style.fontSize = 20 * (clientWidth / 320) + 'px';
};
//alert(docEl)
if (!doc.addEventListener) return;
win.addEventListener(resizeEvt, recalc, false);//addEventListener事件方法接受三個參數:第一個是事件名稱比如點擊事件onclick,第二個是要執(zhí)行的函數,第三個是布爾值
doc.addEventListener('DOMContentLoaded', recalc, false)//綁定瀏覽器縮放與加載時間
})(document, window);
//alert(document.documentElement.clientWidth/320)
</script>
</body>
</html>
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
js和jquery設置disabled屬性為true使按鈕失效
這篇文章主要介紹了js和jquery使按鈕失效的方法,需要的朋友可以參考下2014-08-08
關于JavaScript中parseInt()的一個怪異行為解決
parseInt()是內置的?JS?函數,用于解析數字字符串中的整數,下面這篇文章主要給大家介紹了關于JavaScript中parseInt()的一個怪異行為解決,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-12-12

