国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

vue項目中使用rem,在入口文件添加內容操作

瀏覽:6日期:2022-11-01 08:48:45

在使用vue-cli搭建好項目框架后,在目錄結構的index.html文件中添加一段js代碼:

<script> window.onload = function () { var setRem = function () { // UI設計稿的寬度 var uiWidth = 1200; // 移動端屏幕寬度 var winWidth = document.documentElement.clientWidth; // 比率 var rate = winWidth / uiWidth; // 設置html元素的字體大小 document.documentElement.style.fontSize = rate * 20 + 'px' }; setRem(); window.onresize = function () { setRem(); }}</script>

然后在寫css就可以將px單位換成rem.

這里設置的比例是20px=1rem,

例如:寬度為100px時,可以直接寫成5rem

(function (doc, win) { let fn = () => { let docEl = doc.documentElement, clientWidth = docEl.clientWidth; if (!clientWidth) return; docEl.style.fontSize = 16 * (clientWidth / 1920) + ’px’; } if (!doc.addEventListener) return; win.addEventListener(’resize’, fn); doc.addEventListener(’DOMContentLoaded’, fn); })(document, window);

補充知識:vue 中使用 rem 布局的兩種方法

在使用 vue-cli 開發 H5 項目時,需要進行 rem 適配,下面提供兩種常用的方法(以 750 設計稿為例),希望對大家有所幫助。

方法一:在 index.html 或者 main.js 中添加以下代碼:

const setHtmlFontSize = () => { const htmlDom = document.getElementsByTagName(’html’)[0]; let htmlWidth = document.documentElement.clientWidth || document.body.clientWidth; if (htmlWidth >= 750) { htmlWidth = 750; } if (htmlWidth <= 320) { htmlWidth = 320; } htmlDom.style.fontSize = `${htmlWidth / 7.5}px`;};window.onresize = setHtmlFontSize;setHtmlFontSize();

注: 這里設置的比例是 100px = 1rem,例如:元素寬度為 100px 時,可以直接寫成 1rem

方法二:使用 lib-flexible 和 px2rem-loader 自動轉換

1、安裝插件

npm install lib-flexible --save

npm install px2rem-loader --save-dev

2、配置插件

在入口文件 main.js 中引入 lib-flexible:

vue項目中使用rem,在入口文件添加內容操作

在 build/utils.js 文件中配置 px2rem-loader:

vue項目中使用rem,在入口文件添加內容操作

安裝并配置好 lib-flexible 和 px2rem 之后要重啟一下項目,才能自動把 px 轉換成 rem。

內聯的 px 樣式不能自動轉換。

另外,px 寫法上會有些不同,大家可以參考 px2rem 官方介紹,下面簡單介紹一下。

1. 直接寫 px,編譯后會直接轉化成 rem;---- 【除下面兩種情況,其他長度用這個】

2. 在 px 后面添加 /*no*/,不會轉化 px,會原樣輸出; ---- 【一般 border 用這個】

3. 在 px 后面添加 /*px*/,會根據 dpr 的不同,生成三套代碼。---- 【一般 font-size 用這個】

示例代碼如下:

/* 編譯前 */.selector { width: 150px; height: 64px; /*px*/ font-size: 28px; /*px*/ border: 1px solid #ddd; /*no*/}/* 編譯后 */.selector { width: 2rem; border: 1px solid #ddd;}[data-dpr='1'] .selector { height: 32px; font-size: 14px;}[data-dpr='2'] .selector { height: 64px; font-size: 28px;}[data-dpr='3'] .selector { height: 96px; font-size: 42px;}

以上這篇vue項目中使用rem,在入口文件添加內容操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
主站蜘蛛池模板: 欧美亚洲第一区 | 美女扒开双腿让男人爽透视频 | 久久精品二三区 | 国产在线综合一区二区三区 | 久久91精品国产91久久 | 国产精品视频男人的天堂 | 亚洲一区二区三区视频 | 九九色视频在线观看 | 美女黄色在线看 | 91视频社区| 一区高清 | 亚洲日本va午夜中文字幕一区 | 狠狠澡夜夜澡人人爽 | 欧美大片在线播放 | 成人精品亚洲人成在线 | 美女网站免费观看视频 | 久久成人a毛片免费观看网站 | 亚洲码一区二区三区 | 免费国产成人高清在线看软件 | 丁香伊人五月综合激激激 | 精品久久九九 | 久久综合狠狠综合久久综合88 | 国产精品秦先生手机在线 | 色怡红院| 亚洲高清国产一线久久 | 久久99久久精品免费思思6 | 亚洲精品一区二区观看 | 久久精品高清视频 | 日本高清在线精品一区二区三区 | 日韩成人一级 | 高清国产精品久久久久 | 欧美日韩精品一区二区在线线 | 亚洲精品美女在线观看 | 日本免费的一级绿象 | 亚洲国产爱久久全部精品 | 日韩一级a毛片欧美区 | japanesevideo乱子 japanese日本tube色系 | 国产一区视频在线播放 | 国内精品久久久久久久久 | 亚洲精品国产综合一线久久 | 久草免费手机视频 |