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

您的位置:首頁技術(shù)文章
文章詳情頁

vue項目中使用rem替換px的實現(xiàn)示例

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

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

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

工具

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

安裝插件

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

當(dāng)你切換不同尺寸的屏幕的時候,需要動態(tài)改變根字體的大小,一段簡單的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://m.b3g6.com/public.css' rel='external nofollow' type='text/css'> <link rel='icon' href='http://m.b3g6.com/bcjs/<%= BASE_URL %>favicon.ico' rel='external nofollow' > <title><%= htmlWebpackPlugin.options.title %></title> <script src='http://m.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文件夾找的

關(guān)于

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

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

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

標(biāo)簽: Vue
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美影院三区| 麻豆精品久久久| 国产精品v日韩精品v欧美精品网站| 性欧美69xoxoxoxo| 精品一区欧美| 免费视频一区二区三区在线观看| 欧美99久久| 狠狠色综合网| 麻豆成人在线| 亚洲人成高清| 国产日韩一区| 国产成人免费| 在线一区免费| 日韩欧美中文字幕电影| 国产乱码精品一区二区亚洲| 精品在线网站观看| 久久久夜夜夜| 日韩一区二区三免费高清在线观看| 久久成人精品| 国产精品亚洲综合久久| 国产色播av在线| 欧美专区18| 精品国内亚洲2022精品成人| 欧美日韩免费观看视频| 美女精品一区| 精品国产成人| 一区二区三区网站| 精品91久久久久| 欧美特黄一区| 国产精品久久久久久久久久白浆| 高清一区二区| 亚洲三级国产| 日韩成人亚洲| 免费在线观看视频一区| 国产精品久久久久久久久久妞妞| 亚洲国内精品| 欧美韩一区二区| 国产亚洲欧洲| а√天堂8资源在线| 亚洲欧美在线综合| 色88888久久久久久影院| 欧美亚洲三区| 亚洲网址在线观看| 久久免费黄色| 国产一区二区精品福利地址| 在线精品福利| 伊人久久婷婷| 日韩在线中文| 国产精品一区二区免费福利视频| av不卡免费看| 欧美精品一区二区久久| 日韩精品不卡一区二区| 精品国产一区二区三区噜噜噜| 日韩精品一区二区三区av | 神马午夜久久| 久久久久久色| 日韩制服丝袜av| 伊人影院久久| 视频一区在线视频| 亚洲永久字幕| 免费在线播放第一区高清av| 999国产精品视频| 日韩视频一区| 亚洲福利一区| 丝袜国产日韩另类美女| 在线成人直播| 亚洲免费专区| 日本成人中文字幕| 欧美偷窥清纯综合图区| 欧美精品二区| 捆绑调教日本一区二区三区| 成人午夜精品| 久久av在线| 国产精品欧美在线观看| 高清av一区| 99热免费精品| 日韩视频1区| 久久99影视| 久久久久国产精品一区二区| 欧美日韩视频| 国产日韩1区| 亚洲女同av| 亚洲一区欧美二区| 国产激情综合| 99久久亚洲精品| 一区二区高清| 综合日韩av| 日本在线不卡视频一二三区| 国产91在线精品| 亚洲午夜免费| 日韩精品影视| 国产精品密蕾丝视频下载| 国产一区一一区高清不卡| 午夜在线观看免费一区| 国产日产精品_国产精品毛片 | 日韩欧美一区二区三区在线视频 | 国产精品xx| 久久午夜视频| 老司机精品视频网| 日韩精品一二区| 日韩伦理福利| 国产日韩一区| 中文字幕日韩亚洲| 国产精品88久久久久久| 久久香蕉网站| 欧美性www| 视频在线观看一区二区三区| 四虎国产精品免费观看| 91亚洲精品在看在线观看高清| 久久精品99久久无色码中文字幕| 欧美日本三区| 免费观看在线综合| 蜜臀91精品国产高清在线观看| 国产精区一区二区| 午夜在线一区| 国产亚洲在线| 夜夜精品视频| 伊人久久大香线蕉av超碰演员| 久久久久久久久久久妇女| 日本一区二区高清不卡| 老色鬼精品视频在线观看播放| 欧美亚洲一区二区三区| 日韩精品久久久久久| 亚洲综合图色| 综合国产精品| 婷婷久久免费视频| 日韩免费精品| 国产欧美亚洲一区| 中文字幕中文字幕精品| 日韩综合一区二区三区| 奇米亚洲欧美| 免费在线成人| 亚洲深夜视频| 97精品国产| 久久激情网站| 亚洲精华国产欧美| 亚洲人成亚洲精品| 久久国产免费看| 美女视频黄 久久| 久久精品日韩欧美| 精品三级久久| 久久国产精品久久w女人spa| 亚洲区欧美区| 国产精品欧美在线观看| 中文字幕一区久| 最新亚洲一区| 国产乱码精品一区二区三区亚洲人| 久久三级毛片| 亚洲国产影院| 久久国产精品色av免费看| 国产+成+人+亚洲欧洲在线| 女同性一区二区三区人了人一| 蜜桃91丨九色丨蝌蚪91桃色| 欧美激情麻豆| 激情综合自拍| 欧美日韩一区自拍| 久久精品青草| 欧美亚洲一区二区三区| 国产96在线亚洲| 亚洲精品女人| 日韩精品免费一区二区在线观看| 一区二区电影| 丝袜av一区| 国产欧美三级| 亚洲一区二区毛片| 国产成人免费av一区二区午夜| 综合国产精品| 亚洲韩日在线| 精品国产91| 国产亚洲高清在线观看| 亚洲永久字幕| 天堂资源在线亚洲| 国产精品一区亚洲| 久久成人国产| 亚洲91精品| 国产精品久久久久久久久妇女| 综合五月婷婷| 亚洲二区免费| 成人国产精品一区二区免费麻豆| 日韩精品亚洲aⅴ在线影院| 女人天堂亚洲aⅴ在线观看| 亚洲美女久久精品| 国产精品**亚洲精品| 日本不卡不码高清免费观看| 丝袜亚洲另类欧美| 亚洲第一精品影视| 久久精品国产www456c0m| 精品国产免费人成网站| 国产精品手机在线播放| 日韩**一区毛片| 亚洲精品视频一二三区| 免费观看在线综合色| 欧美资源在线| 亚洲三级国产| 日韩精品a在线观看91| 91亚洲无吗| 麻豆精品新av中文字幕| 精品一区二区三区免费看| 麻豆久久久久久久| 精品久久影院|