成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

rem : web app適配的秘密武器

since1986 / 1233人閱讀

摘要:有與兩種方式來(lái)調(diào)整元素大小的值。如果你的頁(yè)面還需要適配到端,那么就老老實(shí)實(shí)的使用吧。在上面的實(shí)現(xiàn)中,我通過(guò)判斷設(shè)定了字體大小的范圍來(lái)避免上顯示過(guò)于夸張。二有的同學(xué)可能對(duì)的適配有點(diǎn)誤解。

最近看到這樣一個(gè)提問(wèn):我有一個(gè)750 x 1500尺寸的設(shè)計(jì)稿,設(shè)計(jì)稿上有一個(gè)150 x 50的按鈕,那么在寫(xiě)頁(yè)面布局的時(shí)候,應(yīng)該如何確定按鈕的尺寸呢?。大多數(shù)同學(xué)在回答的時(shí)候提到了rem。但我發(fā)現(xiàn)很多同學(xué)對(duì)于rem的實(shí)際應(yīng)用還存在一點(diǎn)小小的疑問(wèn)和誤解。

于是問(wèn)題來(lái)了,rem到底是什么?rem是為了解決什么問(wèn)題而存在的?rem能夠給我們帶來(lái)什么樣的便利?帶著這樣的問(wèn)題,我們一起來(lái)總結(jié)一下rem的實(shí)踐。剛好工作中有一個(gè)移動(dòng)端頁(yè)面的需求要做,就嘗試使用rem完成了一個(gè)小小的頁(yè)面適配。大家可以點(diǎn)擊這里,查看rem適配demo,

建議大家在chrome的device module下打開(kāi),通過(guò)切換不同手機(jī)的模擬器來(lái)查看不同尺寸下的區(qū)別。

rem是什么?

rem是一個(gè)相對(duì)于根元素字體大小的css單位。與px一樣,他可以用來(lái)設(shè)置字體大小,也可以用來(lái)設(shè)置長(zhǎng)度單位。相對(duì)于根元素字體大小是什么意思?

舉個(gè)栗子。在頁(yè)面中,html元素是根元素,因此我們首先給html設(shè)置一個(gè)字體大小

html { font-size: 100px; }

于是,在整個(gè)頁(yè)面中,就有這樣的換算公式 : 1rem = 100px

所以如果一個(gè)按鈕,有如下的css樣式,就等同于他的寬為100px,高50px.

btn { width: 1rem; height: 0.5rem; }

這就是rem這個(gè)知識(shí)點(diǎn)的所有真相了。

?。。∈裁??這就完了?這和px有什么區(qū)別?

對(duì)啊,這和px本來(lái)就沒(méi)有特別的區(qū)別,就是一個(gè)尺寸單位嘛!

所以提問(wèn)的那個(gè)同學(xué)拿著750x1500設(shè)計(jì)圖來(lái)問(wèn),當(dāng)我們?cè)O(shè)置為html的字體大小為100px時(shí),
150x50的按鈕應(yīng)該在頁(yè)面里面寫(xiě)什么尺寸?,用px就應(yīng)該寫(xiě) 75x25,用rem就是 0.75 x 0.25.

真實(shí)寬度375px / 設(shè)計(jì)圖寬度750px = 按鈕真實(shí)寬度 / 設(shè)計(jì)圖按鈕寬度150px
==> 按鈕真實(shí)寬度 = 75px

又 1rem = 100px;   ==> 75px = 0.75rem

有的時(shí)候我們希望在設(shè)計(jì)圖直接量出來(lái)的尺寸不用除2直接得到rem的值,也就是說(shuō)量出來(lái)是150px,那么用rem表示就是1.5rem。這個(gè)時(shí)候我們只需要修改html的字體大小為50px即可。那么計(jì)算思路就有一點(diǎn)不同。

真實(shí)寬度375px / 設(shè)計(jì)圖寬度750px = 按鈕真實(shí)寬度 / 設(shè)計(jì)圖按鈕寬度150px
==> 按鈕真實(shí)寬度 = 75px

又 1rem = 50px;   ==> 75px = 1.5rem

因此當(dāng)設(shè)計(jì)圖的尺寸發(fā)生改變時(shí),我們需要根據(jù)上述思路,動(dòng)態(tài)的調(diào)整html的字體大小,以達(dá)到我們想要的rem換算。

rem是為了解決什么問(wèn)題而存在的?

以iphone各種手機(jī)的尺寸來(lái)說(shuō),iPhone4,5 寬度320px,iPhone6 375px,iPhone6 plus 414px. 如果一個(gè)按鈕,固定一個(gè)75x25的尺寸,那么就必然會(huì)導(dǎo)致在不同尺寸下的相對(duì)大小不一樣。這帶來(lái)的問(wèn)題就在于會(huì)直接影響到設(shè)計(jì)的美觀,可能在iPhone6下,一個(gè)完美的設(shè)計(jì)圖,到了iPhone5,就變得low很多。 因?yàn)?,為了讓?yè)面元素的尺寸能夠在設(shè)備寬度變化的時(shí)候也跟著變化,rem就出現(xiàn)了。

我們已經(jīng)知道,rem的相對(duì)大小跟html元素的字體大小有關(guān)系。使用rem適配的原理就是我們只需要在設(shè)備寬度大小變化的時(shí)候,調(diào)整html的字體大小,那么頁(yè)面上所有使用rem單位的元素都會(huì)相應(yīng)的變化。 這也是rem與px最大的區(qū)別。

有css與js兩種方式來(lái)調(diào)整html元素大小的值。

css方式

html { font-size: calc(100vw / 3.75) }

100vw表示設(shè)備寬度,除以3.75這里是以iphone6 的寬度375px為標(biāo)準(zhǔn),為了保證html的字體大小為100px。這樣我們?cè)趽Q算的時(shí)候,1px 就是0.01rem,就很容易計(jì)算。

因?yàn)閏hrome下最小字體大小為12px,所以不能把html的font-size設(shè)置成1px或者10px,100px是我們最好的選擇。

js方式, 原理與css一樣,不過(guò)為了避免在一些老舊一點(diǎn)的手機(jī)瀏覽器上不支持calc,vm這些屬性,在實(shí)際應(yīng)用中使用js是最好的。

!function () {
   function a() {
       var _width;
       var clientWidth = document.documentElement.clientWidth;
       if (clientWidth > 568) {
           _width = 568;
       } else if (clientWidth < 320) {
           _width = 320;
       } else {
               _width = clientWidth;
       }
       // var pageWid = (window.innerWidth > document.querySelector("body").offsetHeight) ? 1136 : 640;
       document.documentElement.style.fontSize = _width / 375 * 100 + "px";
   }
   var b = null;
   document.addEventListener("DOMContentLoaded", function () {
       window.addEventListener("resize", function () {
           clearTimeout(b);
           b = setTimeout(a, 300)
       }, !1);
       a()
   }, false);
}(window);

在實(shí)踐中還有一個(gè)關(guān)鍵的問(wèn)題需要處理。就是無(wú)論如何js的加載會(huì)比css慢,因此如果我們就這樣的話,頁(yè)面的元素會(huì)有一個(gè)很明顯的閃爍過(guò)程,因?yàn)樵賘s加載進(jìn)來(lái)之前,html的字體大小還沒(méi)有達(dá)到我們想要的效果。因此通常我們需要在css中,給html的字體大小設(shè)置一個(gè)默認(rèn)值,以弱化這個(gè)閃爍的過(guò)程。默認(rèn)值的具體大小需要我們自行根據(jù)設(shè)計(jì)圖的尺寸,以及你想要的結(jié)果,通過(guò)上面我們介紹的計(jì)算思路去得出。

html {
  font-size: 100px;
}
需要注意的地方

一、rem的適用性很有局限,僅僅只能夠用于只在移動(dòng)端展示的頁(yè)面。如果你的頁(yè)面還需要適配到pc端,那么就老老實(shí)實(shí)的使用px吧。在上面的實(shí)現(xiàn)中,我通過(guò)判斷設(shè)定了html字體大小的范圍來(lái)避免pc上顯示過(guò)于夸張。

二、有的同學(xué)可能對(duì)web的適配有點(diǎn)誤解。web中做適配并不需要考慮什么物理像素啊,dpi等等概念。這些應(yīng)該僅僅只是Android或者ios原生app才會(huì)考慮的問(wèn)題。這些誤會(huì)導(dǎo)致許多搞設(shè)計(jì)的同學(xué)在給web app做設(shè)計(jì)的時(shí)候,也丟一張1080 x 1920 的設(shè)計(jì)稿過(guò)來(lái),真是愁死人了。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/21587.html

相關(guān)文章

  • rem : web app適配秘密武器

    摘要:有與兩種方式來(lái)調(diào)整元素大小的值。如果你的頁(yè)面還需要適配到端,那么就老老實(shí)實(shí)的使用吧。在上面的實(shí)現(xiàn)中,我通過(guò)判斷設(shè)定了字體大小的范圍來(lái)避免上顯示過(guò)于夸張。二有的同學(xué)可能對(duì)的適配有點(diǎn)誤解。 最近看到這樣一個(gè)提問(wèn):我有一個(gè)750 x 1500尺寸的設(shè)計(jì)稿,設(shè)計(jì)稿上有一個(gè)150 x 50的按鈕,那么在寫(xiě)頁(yè)面布局的時(shí)候,應(yīng)該如何確定按鈕的尺寸呢?。大多數(shù)同學(xué)在回答的時(shí)候提到了rem。但我發(fā)現(xiàn)很多...

    MageekChiu 評(píng)論0 收藏0
  • rem : web app適配秘密武器

    摘要:有與兩種方式來(lái)調(diào)整元素大小的值。如果你的頁(yè)面還需要適配到端,那么就老老實(shí)實(shí)的使用吧。在上面的實(shí)現(xiàn)中,我通過(guò)判斷設(shè)定了字體大小的范圍來(lái)避免上顯示過(guò)于夸張。二有的同學(xué)可能對(duì)的適配有點(diǎn)誤解。 最近看到這樣一個(gè)提問(wèn):我有一個(gè)750 x 1500尺寸的設(shè)計(jì)稿,設(shè)計(jì)稿上有一個(gè)150 x 50的按鈕,那么在寫(xiě)頁(yè)面布局的時(shí)候,應(yīng)該如何確定按鈕的尺寸呢?。大多數(shù)同學(xué)在回答的時(shí)候提到了rem。但我發(fā)現(xiàn)很多...

    KaltZK 評(píng)論0 收藏0
  • css進(jìn)階

    摘要:柵格系統(tǒng)用于處理頁(yè)面多終端適配的問(wèn)題。它表示抓取對(duì)象以后拖放到另一個(gè)位置。目前,它是標(biāo)準(zhǔn)的一部分。精簡(jiǎn)高效的命名準(zhǔn)則方法這篇文章發(fā)布于年月日,星期日,,歸類于相關(guān)。但是不會(huì)受到包含塊的限制,可能會(huì)溢出。 一勞永逸的搞定 flex 布局 尋根溯源話布局 一切都始于這樣一個(gè)問(wèn)題:怎樣通過(guò) CSS 簡(jiǎn)單而優(yōu)雅的實(shí)現(xiàn)水平、垂直同時(shí)居中。記得剛開(kāi)始學(xué)習(xí) CSS 的時(shí)候,看到 float 屬性不由...

    import. 評(píng)論0 收藏0
  • 移動(dòng)端web app自適應(yīng)布局探索與總結(jié)

    摘要:方案的簡(jiǎn)單介紹基于前提頁(yè)面元素的布局尺寸全都以設(shè)計(jì)稿為基準(zhǔn)等比例設(shè)置。給根節(jié)點(diǎn)設(shè)置一個(gè)基礎(chǔ)值,然后頁(yè)面的所有元素布局均相對(duì)于該值采用單位設(shè)定。 1、困擾多時(shí)的問(wèn)題 在這之前做web app開(kāi)發(fā)的的時(shí)候,在自適應(yīng)方面一般都是寬度通過(guò)百分比,高度以iPhone6跟iPhone5之間的一個(gè)平衡值寫(xiě)死,我們的設(shè)計(jì)稿都是iPhone5的640 * 1136標(biāo)準(zhǔn),所以高度一般取個(gè)大概值,各種圖標(biāo)的...

    Benedict Evans 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<