px2rem 移動端自適應方案

一套設計稿如何適配不同移動端設備?

開發(fā) WebApp 時叶眉,我們通常只會從設計師那邊拿到一個尺寸的項目設計圖家卖,比如是按照 iphone 6 為基礎設計的,因此前端需要讓這一套設計稿能夠通用在不同的設備型號中锁右,本文介紹的方式是采用 hotcss.js 插件。

hotcss.js 會自動根據(jù)手機型號計算 dpr 的值讶泰,同時在 html 根標簽內(nèi)植入一個相應的 font-size 的值咏瑟。

hotcss.js 優(yōu)點

  • 保證不同設備下的統(tǒng)一視覺體驗。
  • 不需要你再手動設置 viewport痪署,根據(jù)當前環(huán)境計算出最適合的 viewport码泞。
  • 支持任意尺寸的設計圖,不局限于特定尺寸的設計圖狼犯。
  • 支持單一項目余寥,多種設計圖尺寸,專為解決大型悯森,長周期項目劈狐。
  • 提供 px2rem 轉(zhuǎn)換方法,CSS 布局呐馆,零成本轉(zhuǎn)換,原始值不丟失莲兢。
  • 有效解決移動端真實 1 像素問題汹来。

px2rem 原理

vue-loader 中使用 px2rem 插件,首先安裝 px2rem-loader

npm install px2rem-loader --save-dev

根據(jù)設計稿所采用的手機型號(如iPhone 6 或 iPhone X)改艇,那么寬度則為 640px750px 收班,因此先在 chrome 調(diào)試工具中獲取移動端的 <html> 根元素的 font-size 的值,然后在配置 vue-loader 時將其設為 remUnit 參數(shù)的值:

loaders: {
   css: 'vue-style-loader!css-loader!px2rem-loader?remUnit=40&remPrecision=8',
   scss: 'vue-style-loader!css-loader!px2rem-loader?remUnit=40&remPrecision=8!sass-loader'
}

這樣就可以根據(jù)設計稿尺寸谒兄,在開發(fā)時寫 CSS 像素的絕對值摔桦,即 px 單位,px2rem 會自動將尺寸轉(zhuǎn)換成相應的 rem 單位承疲,結(jié)合不同終端生成的不同 html 根元素的字體大小邻耕,從而實現(xiàn)一套設計稿在不同設備完美兼容的效果。

Tips

  • 對于一些布局類的樣式寬度燕鸽,通常采用百分比為單位兄世,如 width: 100%; 又如配合box-sizing: border-box; 設置 width: 25%; 可控制一行放4個 div 容器。

  • 對于一些小組件啊研,如按鈕御滩、文字等鸥拧,直接寫設計稿上的 css 尺寸即可。如 font-size, margin, padding, height…… 即使通過 PC 或 Pad 訪問也不會丟失效果削解。

  • 響應式開發(fā)中富弦,一般需要指定一個 min-width,這樣頁面尺寸縮小后氛驮,避免如按鈕里面的文字不會因為外層容器寬度減小而換行腕柜。

項目應用

我將之前做的一個項目目錄結(jié)構(gòu)和 Webpack 配置文件提取出來,生成一個簡易的 WebApp 腳手架柳爽,用于實現(xiàn)本文所述的自適應方案媳握。

Github項目地址:基于Vue的WebApp項目構(gòu)建模板

?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市磷脯,隨后出現(xiàn)的幾起案子蛾找,更是在濱河造成了極大的恐慌,老刑警劉巖赵誓,帶你破解...
    沈念sama閱讀 217,277評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件打毛,死亡現(xiàn)場離奇詭異,居然都是意外死亡俩功,警方通過查閱死者的電腦和手機幻枉,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評論 3 393
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來诡蜓,“玉大人熬甫,你說我怎么就攤上這事÷#” “怎么了椿肩?”我有些...
    開封第一講書人閱讀 163,624評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長豺谈。 經(jīng)常有香客問我郑象,道長,這世上最難降的妖魔是什么茬末? 我笑而不...
    開封第一講書人閱讀 58,356評論 1 293
  • 正文 為了忘掉前任厂榛,我火速辦了婚禮,結(jié)果婚禮上丽惭,老公的妹妹穿的比我還像新娘击奶。我一直安慰自己,他們只是感情好责掏,可當我...
    茶點故事閱讀 67,402評論 6 392
  • 文/花漫 我一把揭開白布正歼。 她就那樣靜靜地躺著,像睡著了一般拷橘。 火紅的嫁衣襯著肌膚如雪局义。 梳的紋絲不亂的頭發(fā)上喜爷,一...
    開封第一講書人閱讀 51,292評論 1 301
  • 那天,我揣著相機與錄音萄唇,去河邊找鬼檩帐。 笑死,一個胖子當著我的面吹牛另萤,可吹牛的內(nèi)容都是我干的湃密。 我是一名探鬼主播,決...
    沈念sama閱讀 40,135評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼四敞,長吁一口氣:“原來是場噩夢啊……” “哼泛源!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起忿危,我...
    開封第一講書人閱讀 38,992評論 0 275
  • 序言:老撾萬榮一對情侶失蹤达箍,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后铺厨,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體缎玫,經(jīng)...
    沈念sama閱讀 45,429評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,636評論 3 334
  • 正文 我和宋清朗相戀三年解滓,在試婚紗的時候發(fā)現(xiàn)自己被綠了赃磨。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,785評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡洼裤,死狀恐怖邻辉,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情腮鞍,我是刑警寧澤恩沛,帶...
    沈念sama閱讀 35,492評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站缕减,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏芒珠。R本人自食惡果不足惜桥狡,卻給世界環(huán)境...
    茶點故事閱讀 41,092評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望皱卓。 院中可真熱鬧裹芝,春花似錦、人聲如沸娜汁。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽掐禁。三九已至怜械,卻和暖如春颅和,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背缕允。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評論 1 269
  • 我被黑心中介騙來泰國打工峡扩, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人障本。 一個月前我還...
    沈念sama閱讀 47,891評論 2 370
  • 正文 我出身青樓教届,卻偏偏與公主長得像,于是被迫代替她去往敵國和親驾霜。 傳聞我的和親對象是個殘疾皇子案训,可洞房花燭夜當晚...
    茶點故事閱讀 44,713評論 2 354

推薦閱讀更多精彩內(nèi)容