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


Posted in Javascript onNovember 11, 2020

在使用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,在入口文件添加内容操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JS 两日期相减,获得天数的小例子(兼容IE,FF)
Jul 01 Javascript
Js判断CSS文件加载完毕的具体实现
Jan 17 Javascript
一个检测表单数据的JavaScript实例
Oct 31 Javascript
JavaScript实现为input与textarea自定义hover,focus效果的方法
Aug 21 Javascript
js获取页面引用的css样式表中的属性值方法(推荐)
Aug 19 Javascript
Node.js中的cluster模块深入解读
Jun 11 Javascript
vuejs+element UI点击编辑表格某一行时获取内容填入表单的示例
Oct 31 Javascript
微信小程序使用template标签实现五星评分功能
Nov 03 Javascript
VueCli3.0中集成MockApi的方法示例
Jul 05 Javascript
vue使用nprogress加载路由进度条的方法
Jun 04 Javascript
详谈vue中router-link和传统a链接的区别
Jul 22 Javascript
简单了解JavaScript作用域
Jul 31 Javascript
VUE前端从后台请求过来的数据进行转换数据结构操作
Nov 11 #Javascript
Vue 防止短时间内连续点击后多次触发请求的操作
Nov 11 #Javascript
Vue 401配合Vuex防止多次弹框的案例
Nov 11 #Javascript
VUE-ElementUI 自定义Loading图操作
Nov 11 #Javascript
在elementui中Notification组件添加点击事件实例
Nov 11 #Javascript
vue.js+element 默认提示中英文操作
Nov 11 #Javascript
Vue 解决在element中使用$notify在提示信息中换行问题
Nov 11 #Javascript
You might like
处理php自动反斜杠的函数代码
2010/01/05 PHP
备份mysql数据库的php代码(一个表一个文件)
2010/05/28 PHP
php安全开发 添加随机字符串验证,防止伪造跨站请求
2013/02/14 PHP
基于php split()函数的用法详解
2013/06/05 PHP
在yii中新增一个用户验证的方法详解
2013/06/20 PHP
ThinkPHP实现动态包含文件的方法
2014/11/29 PHP
Yii框架中memcache用法实例
2014/12/03 PHP
使用图灵api创建微信聊天机器人
2015/07/23 PHP
基于PHP常用文件函数和目录函数整理
2017/08/17 PHP
php获取ajax的headers方法与内容实例
2017/12/27 PHP
js中cookie的使用详细分析
2008/05/28 Javascript
javascript下判断一个对象是否具有指定名称的属性的的代码
2010/01/11 Javascript
固定表格行列(expression)在IE下适用
2013/07/25 Javascript
网站接入QQ登录的两种方法
2014/07/22 Javascript
javascript制作坦克大战全纪录(1)
2014/11/27 Javascript
JavaScript中isPrototypeOf函数作用和使用实例
2015/06/01 Javascript
JS实时弹出新消息提示框并有提示音响起的实现代码
2016/04/20 Javascript
基于JavaScript代码实现自动生成表格
2016/06/15 Javascript
JavaScript reduce和reduceRight详解
2016/10/24 Javascript
Angular6封装http请求的步骤详解
2018/08/13 Javascript
基于vue-cli、elementUI的Vue超简单入门小例子(推荐)
2019/04/17 Javascript
详解基于Vue/React项目的移动端适配方案
2019/08/23 Javascript
详解JavaScript中new操作符的解析和实现
2020/09/04 Javascript
Python简单连接MongoDB数据库的方法
2016/03/15 Python
matplotlib实现热成像图colorbar和极坐标图的方法
2018/12/13 Python
python中的数据结构比较
2019/05/13 Python
解决pyqt5中QToolButton无法使用的问题
2019/06/21 Python
基于Python实现签到脚本过程解析
2019/10/25 Python
python numpy数组中的复制知识解析
2020/02/03 Python
Python如何实现的二分查找算法
2020/05/27 Python
HTML5 拖放(Drag 和 Drop)详解与实例代码
2017/09/14 HTML / CSS
餐饮投资计划书
2014/04/25 职场文书
学校师德承诺书
2014/05/23 职场文书
党的群众路线教育实践活动对照检查剖析材料
2014/10/09 职场文书
个人债务授权委托书
2014/10/17 职场文书
团代会开幕词
2015/01/28 职场文书