日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

vue項目中使用rem替換px的實現示例

瀏覽:269日期:2022-09-28 13:04:59
目錄工具安裝插件在項目根目錄下添加.postcssrc.js文件index.html關于

移動端頁面適配,rem和vw適配方案

基礎點:rem相對根節點字體的大小。所以不用px;根字體:字體的大小px;px:你就當成cm(厘米)這樣的東西吧;基準:750設計稿(一般UI設計師給的都是750的設計稿);

工具

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='http://www.b3g6.com/public.css' rel='external nofollow' type='text/css'> <link rel='icon' href='http://www.b3g6.com/bcjs/<%= BASE_URL %>favicon.ico' rel='external nofollow' > <title><%= htmlWebpackPlugin.options.title %></title> <script src='http://www.b3g6.com/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 style='background-color: #aaa; padding:8px; border:solid 7px #000; height:200px; width:500px; overflow:hidden;'><div 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,他的計算是內容寬+2paddinggetWidth(也就是getBoundingClientRect().width)包括內容寬+2padding+2border第五步:就是將設計稿上的px轉換成rem為單位:安裝 cssrem插件 (在插件市場):然后在 文件-->首選項-->設置 然后搜索cssrem 設置Root Font Size為16即可

到此這篇關于vue項目中使用rem替換px的實現示例的文章就介紹到這了,更多相關vue rem替換px內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美.日韩.国产.一区.二区| 久久a爱视频| 亚洲网站视频| 日本免费一区二区三区四区| 黑森林国产精品av| 91一区二区三区四区| 精品国产美女a久久9999| 欧美激情五月| 男女性色大片免费观看一区二区| 久久中文字幕一区二区三区| 免费观看久久av| 日本亚洲视频在线| 亚洲激情黄色| 在线视频观看日韩| 午夜精品一区二区三区国产| 国产一区二区三区四区大秀 | 免费在线亚洲欧美| 日韩在线网址| 亚洲香蕉网站| 亚洲丝袜美腿一区| 麻豆精品视频在线| 欧美专区一区二区三区| 欧美日韩亚洲在线观看| 日韩欧美一区二区三区在线观看| 激情国产在线| 久久婷婷久久| 夜久久久久久| 亚洲精品伊人| 青青国产91久久久久久| 国产精品一区二区三区美女| 91综合久久爱com| 日韩中文字幕亚洲一区二区va在线 | 男女性色大片免费观看一区二区| 国产一区二区三区日韩精品| 免费日韩一区二区三区| 一区久久精品| 免费在线看一区| 久久亚洲国产精品尤物| 国产精品腿扒开做爽爽爽挤奶网站| 夜夜嗨一区二区三区| 成人午夜国产| 亚洲黄页一区| 欧美亚洲国产精品久久| 久久久久久久久成人| 欧美~级网站不卡| 日韩黄色大片| 久久精品资源| 日本欧美一区二区| 欧美亚洲tv| 性色一区二区| 精品欧美一区二区三区在线观看| 蜜桃视频免费观看一区| 久久xxx视频| 国产亚洲一区二区三区不卡| 在线一区二区三区视频| 激情婷婷综合| 亚洲伊人av| 亚洲经典在线| 亚洲精华国产欧美| 91欧美在线| 国产成人久久| 久久久精品国产**网站| 亚洲综合五月| 中文字幕成在线观看| 亚洲小说欧美另类婷婷| 黄色亚洲在线| 日韩一区精品| 精品国内亚洲2022精品成人 | 一区免费在线| 红桃视频亚洲| 另类av一区二区| 爽好久久久欧美精品| 丝袜美腿成人在线| 色婷婷狠狠五月综合天色拍| 日韩精品三区四区| 日韩av字幕| 亚洲+小说+欧美+激情+另类| 一本色道久久精品| aa国产精品| 亚洲婷婷丁香| 日韩高清一区| 欧美国产极品| 成人国产精选| 播放一区二区| 在线亚洲欧美| 亚欧洲精品视频在线观看| 91九色综合| 老牛影视精品| 国产毛片一区| 日韩一区二区三区免费视频| 国产精品久久久久久久久久妞妞| 精品一区二区三区中文字幕| 久久av中文| 婷婷成人综合| 午夜电影一区| 久久成人高清| 亚洲激情偷拍| 免费亚洲婷婷| 久久一区欧美| jizzjizz中国精品麻豆| 日av在线不卡| 亚洲视频综合| 在线观看一区| 国产精品成人国产| 国产精品视频首页| 日韩电影免费网址| 日本欧美国产| 国产精品巨作av| 波多野结衣一区| 国产不卡av一区二区| 久久一级电影| 欧美91在线|欧美| 免费亚洲一区| 久久久久亚洲| 中文字幕一区二区av| 国产乱码精品一区二区三区四区| 亚洲三级观看| 亚洲成a人片| 综合激情在线| 欧美日韩一区自拍| 日韩专区一卡二卡| 久久精品一本| 久久激情av| 美女尤物久久精品| 日韩中文字幕av电影| а√在线中文在线新版| 狠狠久久婷婷| 亚洲免费影院| 今天的高清视频免费播放成人| 欧美aⅴ一区二区三区视频| 男女精品网站| 亚洲视频播放| 国产成人精品亚洲线观看| 91成人在线| 国产一区日韩| 久久狠狠久久| 视频国产精品| 亚洲精品网址| 91精品高清| 视频一区二区三区中文字幕| 欧美国产小视频| 99久久夜色精品国产亚洲1000部| 午夜精品亚洲| 久久蜜桃精品| 日韩欧美精品| 国产亚洲字幕| 在线亚洲欧美| 国产伊人精品| 国产精品伊人| 香蕉视频亚洲一级| 久热精品在线| 在线国产精品一区| 99久久久国产精品美女| 亚洲精品.com| 欧美日韩免费观看一区=区三区 | 欧美日韩一视频区二区| 日韩精品免费视频一区二区三区| 久久福利一区| 亚洲人成网77777色在线播放| 中文字幕日韩亚洲| 日韩高清中文字幕一区| 国产精品天天看天天狠| 国产成人调教视频在线观看| 亚洲欧洲av| 欧美日本不卡| 色乱码一区二区三区网站| 久久精品72免费观看| 久久一区精品| 欧美/亚洲一区| 97成人在线| 蜜桃视频在线网站| 欧美专区18| 国产精品一区二区三区美女 | 国产成人免费| 99国产精品一区二区| 国内精品99| 国产精品s色| 国产一区观看| 国产日韩欧美一区二区三区| 91欧美在线| 日韩高清一区二区| 久久久久亚洲| 国产欧美88| 日韩午夜在线| 麻豆国产一区| 久久视频精品| 国产精品嫩草影院在线看| 99国产精品一区二区| 日韩欧美四区| 日韩免费高清| 久久精品72免费观看| 91久久久精品国产| 国产在视频一区二区三区吞精| 亚洲色图网站| 免费久久久久久久久| 久久精品欧洲| 日韩激情一区二区| 亚洲少妇诱惑| 米奇777超碰欧美日韩亚洲| 免费视频一区二区三区在线观看 |