<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        js實現rem自動匹配計算font-size的示例

        來源:懂視網 責編:小OO 時間:2020-11-27 20:05:50
        文檔

        js實現rem自動匹配計算font-size的示例

        實際開發過程中,我們經常會被各種寬度,高度計算搞暈。尤其是使用了rem的計算方式,自適應布局難倒一大片程序員。為了解決這類問題,我覺得可以利用js監聽屏幕寬度變化來實現更改HTML 根元素font-size的值。下面是相關JavaScript的實現代碼。此代碼選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。
        推薦度:
        導讀實際開發過程中,我們經常會被各種寬度,高度計算搞暈。尤其是使用了rem的計算方式,自適應布局難倒一大片程序員。為了解決這類問題,我覺得可以利用js監聽屏幕寬度變化來實現更改HTML 根元素font-size的值。下面是相關JavaScript的實現代碼。此代碼選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。

        本篇文章主要介紹了js實現rem自動匹配計算font-size的示例,小編覺得挺不錯的,現在分享js源碼給大家,也給大家做個參考。對js感興趣的一起跟隨小編過來看看吧

        實際開發過程中,我們經常會被各種寬度,高度計算搞暈。尤其是使用了rem的計算方式,自適應布局難倒一大片程序員。為了解決這類問題,我覺得可以利用js監聽屏幕寬度變化來實現更改HTML 根元素font-size的值。

        下面是相關JavaScript的實現代碼:

        此代碼選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。

        比如當頁面中某一p的寬度為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>
         <p class="box">
         <p class="public left">左</p>
         <p class="public center">中</p>
         <p class="public right">右</p>
         <p class="public left">左</p>
         <p class="public center">中</p>
         <p class="public right">右</p>
         </p>
         <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>

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        js實現rem自動匹配計算font-size的示例

        實際開發過程中,我們經常會被各種寬度,高度計算搞暈。尤其是使用了rem的計算方式,自適應布局難倒一大片程序員。為了解決這類問題,我覺得可以利用js監聽屏幕寬度變化來實現更改HTML 根元素font-size的值。下面是相關JavaScript的實現代碼。此代碼選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。
        推薦度:
        標簽: js 計算 size
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 国产免费av片在线看| 亚洲伊人久久大香线蕉啊| 亚洲国产美女精品久久久久∴| 精品日韩亚洲AV无码一区二区三区 | 亚洲专区一路线二| 亚洲剧情在线观看| 久久嫩草影院免费看夜色| 青娱乐免费视频在线观看| 亚洲人成国产精品无码| 亚洲国产日韩精品| 成全高清在线观看免费| 男女啪啪永久免费观看网站| 国产∨亚洲V天堂无码久久久| 亚洲精华国产精华精华液| 在线看无码的免费网站| 亚洲人成无码网站| 国产精品亚洲精品日韩动图| 0588影视手机免费看片| 久久亚洲国产中v天仙www| 国产亚洲精彩视频| 精品久久久久国产免费| 亚洲午夜久久久精品影院| 一级成人a免费视频| 好吊妞998视频免费观看在线| 久久精品国产亚洲AV嫖农村妇女| 国产精品极品美女自在线观看免费| 大香人蕉免费视频75| 亚洲精品国产专区91在线| a毛片在线免费观看| av无码东京热亚洲男人的天堂| 99亚偷拍自图区亚洲| 无码国产精品一区二区免费16| 亚洲性久久久影院| 香蕉视频亚洲一级| 成人免费视频网址| 亚洲一卡2卡3卡4卡国产网站 | 一级日本高清视频免费观看| 成人免费一级毛片在线播放视频| 亚洲AV日韩AV鸥美在线观看| 久久国产免费直播| 久久久久亚洲精品中文字幕|