本文將為大家詳細(xì)介紹“Vue中rem與postcss-pxtorem怎么用”,內(nèi)容步驟清晰詳細(xì),細(xì)節(jié)處理妥當(dāng),而小編每天都會更新不同的知識點,希望這篇“Vue中rem與postcss-pxtorem怎么用”能夠給你意想不到的收獲,請大家跟著小編的思路慢慢深入,具體內(nèi)容如下,一起去收獲新知識吧。
十年的雞東網(wǎng)站建設(shè)經(jīng)驗,針對設(shè)計、前端、開發(fā)、售后、文案、推廣等六對一服務(wù),響應(yīng)快,48小時及時工作處理。成都全網(wǎng)營銷推廣的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動調(diào)整雞東建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計,從而大程度地提升瀏覽體驗。創(chuàng)新互聯(lián)公司從事“雞東網(wǎng)站設(shè)計”,“雞東網(wǎng)站推廣”以來,每個客戶項目都認(rèn)真落實執(zhí)行。
Vue具體輕量級框架、簡單易學(xué)、雙向數(shù)據(jù)綁定、組件化、數(shù)據(jù)和結(jié)構(gòu)的分離、虛擬DOM、運(yùn)行速度快等優(yōu)勢,Vue中頁面使用的是局部刷新,不用每次跳轉(zhuǎn)頁面都要請求所有數(shù)據(jù)和dom,可以大大提升訪問速度和用戶體驗。
rem 布局
rem是根元素(html)中的font-size值。
rem布局不多贅述,有很多詳細(xì)說明rem布局原理的資料。
簡單的說,通過JS獲取設(shè)備寬度動態(tài)設(shè)定rem值,以實現(xiàn)在不同寬度的頁面中使用rem作為單位的元素自適應(yīng)的效果。
新建rem.js文件,于main.js中引用
// 設(shè)計稿以1920px為寬度,而我把頁面寬度設(shè)計為10rem的情況下 const baseSize = 192; // 這個是設(shè)計稿中1rem的大小。 function setRem() { // 實際設(shè)備頁面寬度和設(shè)計稿的比值 const scale = document.documentElement.clientWidth / 1920; // 計算實際的rem值并賦予給html的font-size document.documentElement.style.fontSize = (baseSize * scale) + 'px'; } setRem(); window.addEventListener('resize', () => { setRem(); });
postcss-pxtorem
postcss-pxtorem是PostCSS的插件,用于將像素單元生成rem單位。
安裝
新建Vue項目
安裝 postcss-pxtorem
npm install postcss-pxtorem --save-dev
配置
可以通過3個地方來添加配置,配置文件皆位于vue 項目根目錄中,若文件不存在可以自行建立。
其中最重要的是這個:
rootValue (Number)
根元素的值,即1rem的值
用于設(shè)計稿元素尺寸/rootValue
比如 rootValue = 192 時,在css中width: 960px; 最終會換算成width: 5rem;
還有一些其他的配置:
propList (Array) 需要做單位轉(zhuǎn)化的屬性.
必須精確匹配
用 * 來選擇所有屬性. Example: ['*']
在句首和句尾使用 * (['*position*'] 會匹配 background-position-y)
使用 ! 來配置不匹配的屬性. Example: ['*', '!letter-spacing']
組合使用. Example: ['*', '!font*']
minPixelValue(Number) 可以被替換的最小像素.
unitPrecision(Number) rem單位的小數(shù)位數(shù)上限.
完整的可以看官方文檔
權(quán)重
vue.config.js > .postcssrx.js > postcss.config.js
其中 postcssrc.js 和 postcss.config.js 可以熱更新, vue.config.js 中做的修改要重啟devServer
配置示例
vue.config.js
module.exports = { //...其他配置 css: { loaderOptions: { postcss: { plugins: [ require('postcss-pxtorem')({ rootValue: 192, minPixelValue: 2, propList: ['*'], }) ] } } }, }
.postcssrx.js
module.exports = { plugins: { 'postcss-pxtorem': { rootValue: 16, minPixelValue: 2, propList: ['*'], } } }
postcss.config.js
module.exports = { plugins: { 'postcss-pxtorem': { rootValue: 192, minPixelValue: 2, propList: ['*'], } } }
如果你能讀到這里,小編希望你對“Vue中rem與postcss-pxtorem怎么用”這一關(guān)鍵問題有了從實踐層面最深刻的體會,具體使用情況還需要大家自己動手實踐使用過才能領(lǐng)會,如果想閱讀更多相關(guān)內(nèi)容的文章,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!