前端開發中還原設計圖的重要性毋庸置疑,目前來說應用最多的應該也還是使用rem。然而很多人依然還是處於刀耕火種的時代,要么自己去計算rem
值,要么依靠編輯器安裝插件轉換。
而本文的目標就是通過一系列的配置后,在開發中可以直接使用設計圖的尺寸開發,項目為我們自動編譯,轉換成rem
。
技術棧
- vue-cli:使用腳手架工具創建項目。
- postcss-pxtorem:轉換px為rem的插件。
-------------------------------------------
自動設置根節點html
的font-size
因為rem
單位是相對於根節點的字體大小的,所以通過設置根節點的字體大小可以動態的改變rem的大小。
原理網上有很多文章分享,這里不具體解釋。
1、創建rem.js
文件
很多人寫這種小工具文件會習慣性的加上閉包,這個其實是沒有必要的。ES6中每個文件都是單獨的一個模塊。
// 基准大小 const baseSize = 32 // 設置 rem 函數 function setRem () { // 當前頁面寬度相對於 750 寬的縮放比例,可根據自己需要修改。 const scale = document.documentElement.clientWidth / 750 // 設置頁面根節點字體大小 document.documentElement.style.fontSize = (baseSize * Math.min(scale, 2)) + 'px' } // 初始化 setRem() // 改變窗口大小時重新設置 rem window.onresize = function () { setRem() }
2、在main.js
中引入rem.js
import './utils/rem'
引入文件后,查看頁面的html節點,是否有被自動添加 font-size
。
注意:完成到這一步,也就是實現了rem布局,實際開發的時候,還是需要我們去計算對應的rem值去開發。
下一步我們就配置一下webpack,自動轉換px為對應的rem值。
配置 postcss-pxtorem
自動轉換px為rem
1、安裝 postcss-pxtorem
$ npm install postcss-pxtorem -D
2、修改根目錄 .postcssrc.js
文件
找到 plugins 屬性新增pxtorem的設置 "postcss-pxtorem": { "rootValue": 32, "propList": ["*"], // 注意:如果有使用第三方UI如VUX,則需要配置下忽略選擇器不轉換。 // 規則是class中包含的字符串,如vux中所有的class前綴都是weui-。也可以是正則。 "selectorBlackList": ["weui-"] }
按照上述配置項目后,即可在開發中直接使用 px
單位開發。
例如設計給出的設計圖是 750 * 1136,那么可以直接在頁面中寫
body { width: 750px; height: 1136px; }
將被轉換為
body { widht: 23.4375rem; height: 35.5rem; }
注意:此方法支持import
和 .vue
單文件中style
。暫不支持style
中使用@import url();
---End---