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 相关文章推荐
Javascript实例教程(19) 使用HoTMetal(6)
Dec 23 Javascript
地址栏上的一段语句,改变页面的风格。(教程)
Apr 02 Javascript
jQuery弹性滑动导航菜单实现思路及代码
May 02 Javascript
用unescape反编码得出汉字示例
Apr 24 Javascript
jQuery实现Email邮箱地址自动补全功能代码
Nov 03 Javascript
原生js实现弹出层效果
Jan 20 Javascript
javascript  数组排序与对象排序的实例
Jul 17 Javascript
微信小程序之页面拦截器的示例代码
Sep 07 Javascript
Mac下安装vue
Apr 11 Javascript
浅析vue-router原理
Oct 19 Javascript
在Vue mounted方法中使用data变量详解
Nov 05 Javascript
vue实现多个echarts根据屏幕大小变化而变化实例
Jul 19 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图片的裁剪与缩放生成符合需求的缩略图
2013/01/11 PHP
浅析使用Turck-mmcache编译来加速、优化PHP代码
2013/06/20 PHP
php实现图片添加描边字和马赛克的方法
2014/12/10 PHP
浅析PHP数据导出知识点
2018/02/17 PHP
php文件上传原理与实现方法详解
2019/12/20 PHP
数据结构之利用PHP实现二分搜索树
2020/10/25 PHP
列表内容的选择
2006/06/30 Javascript
javascript 自动转到命名锚记
2009/01/10 Javascript
js实现简单的左右两边固定广告效果实例
2015/04/10 Javascript
JS如何实现文本框随文本的长度而增长
2015/07/30 Javascript
原生js模拟淘宝购物车项目实战
2015/11/18 Javascript
swiper 解决动态加载数据滑动失效的问题
2018/02/26 Javascript
vue中使用gojs/jointjs的示例代码
2018/08/24 Javascript
puppeteer库入门初探
2019/01/09 Javascript
Vue 中使用lodash对事件进行防抖和节流操作
2020/07/26 Javascript
angular共享依赖的解决方案分享
2020/10/15 Javascript
javascript实现多边形碰撞检测
2020/10/24 Javascript
vue+element UI实现树形表格
2020/12/29 Vue.js
详解Python中find()方法的使用
2015/05/18 Python
Python基于回溯法子集树模板解决全排列问题示例
2017/09/07 Python
详解appium+python 启动一个app步骤
2017/12/20 Python
详解Python 实现元胞自动机中的生命游戏(Game of life)
2018/01/27 Python
python实现简单flappy bird
2018/12/24 Python
Python使用sklearn库实现的各种分类算法简单应用小结
2019/07/04 Python
Python传递参数的多种方式(小结)
2019/09/18 Python
Pycharm创建项目时如何自动添加头部信息
2019/11/14 Python
python爬虫把url链接编码成gbk2312格式过程解析
2020/06/08 Python
Python实现微信表情包炸群功能
2021/01/28 Python
Talbots官网:美国成熟女装品牌
2019/11/15 全球购物
WebSphere面试题:在WebSphere里面如何部署一个应用
2015/08/02 面试题
消防安全责任书
2014/04/14 职场文书
给客户的感谢信
2015/01/21 职场文书
高中社区服务活动报告
2015/02/05 职场文书
2016新年慰问信范文
2015/03/25 职场文书
SQL 尚未定义空闲 CPU 条件 - OnIdle 作业计划将不起任何作用
2021/06/30 SQL Server
Spark SQL 2.4.8 操作 Dataframe的两种方式
2021/10/16 SQL Server