溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue中rem與postcss-pxtorem怎么用

發布時間:2021-02-25 11:14:28 來源:億速云 閱讀:623 作者:清風 欄目:web開發

本文將為大家詳細介紹“Vue中rem與postcss-pxtorem怎么用”,內容步驟清晰詳細,細節處理妥當,而小編每天都會更新不同的知識點,希望這篇“Vue中rem與postcss-pxtorem怎么用”能夠給你意想不到的收獲,請大家跟著小編的思路慢慢深入,具體內容如下,一起去收獲新知識吧。

Vue的優點

Vue具體輕量級框架、簡單易學、雙向數據綁定、組件化、數據和結構的分離、虛擬DOM、運行速度快等優勢,Vue中頁面使用的是局部刷新,不用每次跳轉頁面都要請求所有數據和dom,可以大大提升訪問速度和用戶體驗。

rem 布局

rem是根元素(html)中的font-size值。

rem布局不多贅述,有很多詳細說明rem布局原理的資料。

簡單的說,通過JS獲取設備寬度動態設定rem值,以實現在不同寬度的頁面中使用rem作為單位的元素自適應的效果。

新建rem.js文件,于main.js中引用

// 設計稿以1920px為寬度,而我把頁面寬度設計為10rem的情況下

const baseSize = 192; // 這個是設計稿中1rem的大小。
function setRem() {
  // 實際設備頁面寬度和設計稿的比值
  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的值

  • 用于設計稿元素尺寸/rootValue

  • 比如 rootValue = 192 時,在css中width: 960px; 最終會換算成width: 5rem;

還有一些其他的配置:

propList (Array) 需要做單位轉化的屬性.

  • 必須精確匹配

  • 用 * 來選擇所有屬性. Example: ['*']

  • 在句首和句尾使用 * (['*position*'] 會匹配 background-position-y)

  • 使用 ! 來配置不匹配的屬性. Example: ['*', '!letter-spacing']

  • 組合使用. Example: ['*', '!font*']

minPixelValue(Number) 可以被替換的最小像素.

unitPrecision(Number) rem單位的小數位數上限.

完整的可以看官方文檔

權重

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怎么用”這一關鍵問題有了從實踐層面最深刻的體會,具體使用情況還需要大家自己動手實踐使用過才能領會,如果想閱讀更多相關內容的文章,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女