中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在加班利用rem自動匹配計算font-size

發布時間:2021-04-08 16:14:25 來源:億速云 閱讀:162 作者:Leah 欄目:web開發

本篇文章為大家展示了怎么在加班利用rem自動匹配計算font-size,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

(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邏輯像素,與設備的物理像素是有區別的。如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,第二個是要執行的函數,第三個是布爾值
     doc.addEventListener('DOMContentLoaded', recalc, false)//綁定瀏覽器縮放與加載時間
    })(document, window);
    //alert(document.documentElement.clientWidth/320)

  </script>
 </body>
</html>

上述內容就是怎么在加班利用rem自動匹配計算font-size,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

木兰县| 遵义市| 岳普湖县| 永和县| 顺义区| 临夏县| 阳山县| 南召县| 高雄市| 广水市| 聂拉木县| 津市市| 米林县| 乌兰察布市| 息烽县| 兴海县| 共和县| 丘北县| 广南县| 蓝田县| 连州市| 乐业县| 登封市| 潢川县| 浮山县| 石泉县| 阆中市| 芜湖市| 门源| 阿克苏市| 达孜县| 永兴县| 玉屏| 抚远县| 尉犁县| 上杭县| 游戏| 安溪县| 贞丰县| 周至县| 观塘区|