中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

vue中怎么使用rem替換px

發布時間:2022-10-11 15:51:43 來源:億速云 閱讀:142 作者:iii 欄目:開發技術

這篇文章主要介紹“vue中怎么使用rem替換px”,在日常操作中,相信很多人在vue中怎么使用rem替換px問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”vue中怎么使用rem替換px”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

工具

vue-cli:使用腳手架來搭建vue前端項目
postcss:就是postcss用js插件幫你轉換css樣式的一個工具。比如,這里的把你的文件里面16px替換成1rem(根大小默認16px的情況);這樣你就不用自己去算了!
cssrem:主要是幫你把px(UI設計給設計稿上的px)轉換成對應的rem
然后:還要用js代碼去動態算根目錄應該有的字體大小,反正就是一段js代碼去動態獲取屏幕寬度

安裝插件

npm i postcss,postcss-pxtorem,postcss-loader,postcss-import,postcss-url

然后再index.html里面加上

<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">

在項目根目錄下添加.postcssrc.js文件

module.exports = {
    "plugins": {
      "postcss-import": {},      //用于@import導入css文件
      "postcss-url": {},           //路徑引入css文件或node_modules文件
      "postcss-aspect-ratio-mini": {},   //用來處理元素容器寬高比
      "postcss-write-svg": { utf8: false },    //用來處理移動端1px的解決方案。該插件主要使用的是border-image和background來做1px的相關處理。
      "postcss-cssnext": {},  //該插件可以讓我們使用CSS未來的特性,其會對這些特性做相關的兼容性處理。
      "postcss-px-to-viewport": {    //把px單位轉換為vw、vh、vmin或者vmax這樣的視窗單位,也是vw適配方案的核心插件之一。
          viewportWidth: 750,    //視窗的寬度
          viewportHeight: 1334,   //視窗的高度
          unitPrecision: 3,    //將px轉化為視窗單位值的小數位數
          viewportUnit: "vw",    //指定要轉換成的視窗單位值
          selectorBlackList: [".ignore", ".hairlines"],    //指定不轉換視窗單位值得類,可以自定義,可以無限添加
          minPixelValue: 1,    //小于等于1px不轉換為視窗單位
          mediaQuery: false   //允許在媒體查詢中使用px
      },
      "postcss-viewport-units":{}, //給vw、vh、vmin和vmax做適配的操作,這是實現vw布局必不可少的一個插件
      "cssnano": {    //主要用來壓縮和清理CSS代碼。在Webpack中,cssnano和css-loader捆綁在一起,所以不需要自己加載它。
          preset: "advanced",   //重復調用
          autoprefixer: false,    //cssnext和cssnano都具有autoprefixer,事實上只需要一個,所以把默認的autoprefixer刪除掉,然后把cssnano中的autoprefixer設置為false。
          "postcss-zindex": false   //只要啟用了這個插件,z-index的值就會重置為1
       } 
    }
  }

當你切換不同尺寸的屏幕的時候,需要動態改變根字體的大小,一段簡單的js插入在head里面:在public目錄下直接新建的shipei.js,然后將這個js引入到index.html的head里面

//shipei.js
(function() {
   function autoRootFontSize() {
       document.documentElement.style.fontSize =        Math.min(screen.width,document.documentElement.getBoundingClientRect().width)  /  750 * 32 + "px";
         // 取screen.width和document.documentElement.getBoundingClientRect().width的最小值;除以750,乘以32;懂的起撒,就是原本是750大小的32px;如果屏幕大小變成了375px,那么字體就是16px;也就是根字體fontSize大小和屏幕大小成正比變化!是不是很簡單
   }
   window.addEventListener("resize", autoRootFontSize);
   autoRootFontSize();
})();

index.html

<!DOCTYPE html>
<html lang="">
  <head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <link rel="stylesheet" href="/public.css" rel="external nofollow"  type="text/css">
    <link rel="icon" href="<%= BASE_URL %>favicon.ico" rel="external nofollow" >
    <title><%= htmlWebpackPlugin.options.title %></title>
    <script src="/shipei.js" type="text/javascript" charset="utf-8"></script>
  </head>
  <body>
    
    <div id="app"></div>
    <!-- built files will be auto injected -->
  </body>
</html>

注意 放到 public 里的東西,可以不用寫開頭目錄,腳手架打包的時候找不到,會去public文件夾找的

關于

getBoundingClientRect().width獲取到的其實是父級的右邊距離瀏覽器原點(0,0)左邊距離瀏覽器原點(0,0)的距離,即父級的寬度+2padding+2border。
此時的clientWidth等于父級的寬度+2*padding,不包括邊框的寬度。
當不隱藏子級內容,即overflow為auto時,前者的寬度依然為這個數字,因為父級并沒有改編盒模型。后者的寬度為上述得到的寬度-滾動條的寬度(17px);

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title></title>
        <style type="text/css">
            *{
                margin: 0;
                padding: 0;
            }
        </style>
    </head>
    <body>
        <div id="divParent" style="background-color: #aaa; padding:8px; border:solid 7px #000; height:200px; width:500px; overflow:hidden;">
                <div id="divDisplay" style="background-color: #0f0; margin: 30px; padding: 10px;
                    height: 400px; width: 600px; border: solid 3px #f00;">
                </div>
            </div>
    </body>
</html>
<script type="text/javascript">
    /* 
     getBoundingClientRect().width獲取到的其實是父級的右邊距離瀏覽器原點(0,0)左邊距離瀏覽器原點(0,0)的距離,即父級的寬度+2padding+2border。
     此時的clientWidth等于父級的寬度+2*padding,不包括邊框的寬度。
     當不隱藏子級內容,即overflow為auto時,前者的寬度依然為這個數字,因為父級并沒有改編盒模型。后者的寬度為上述得到的寬度-滾動條的寬度(17px);例子如下:
     */
     var divP = document.getElementById("divParent");
            var divD = document.getElementById("divDisplay");
    
            var clientWidth = divP.clientWidth;
            var getWidth = divP.getBoundingClientRect().width;
            divD.innerHTML += "clientWidth: " + clientWidth + "<br/>";
            divD.innerHTML += "getWidth: " + getWidth + "<br/>";
</script>

運行結果是clientWidth為516,他的計算是內容寬+2padding
getWidth(也就是getBoundingClientRect().width)包括內容寬+2padding+2border
第五步:就是將設計稿上的px轉換成rem為單位:安裝 cssrem插件 (在插件市場):
然后在 文件-->首選項-->設置 然后搜索cssrem 設置Root Font Size為16即可

到此,關于“vue中怎么使用rem替換px”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

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

AI

梨树县| 乐业县| 高碑店市| 海原县| 大姚县| 旬阳县| 兴宁市| 连城县| 应城市| 昌江| 万盛区| 行唐县| 龙州县| 清徐县| 鹤山市| 遵化市| 亳州市| 贡觉县| 白银市| 沐川县| 英吉沙县| 乌审旗| 陆川县| 玉门市| 镇巴县| 盈江县| 东乌| 公主岭市| 扶风县| 永靖县| 沙雅县| 荣昌县| 苍梧县| 东乡县| 台安县| 张家口市| 延吉市| 繁昌县| 安新县| 文水县| 莎车县|