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 相关文章推荐
Domino中运用jQuery读取视图内容的方法
Oct 21 Javascript
Dojo 学习笔记入门篇 First Dojo Example
Nov 15 Javascript
javascript模拟的Ping效果代码 (Web Ping)
Mar 13 Javascript
Node.js中使用Log.io在浏览器中实时监控日志(等同tail -f命令)
Sep 17 Javascript
学习JavaScript设计模式(策略模式)
Nov 26 Javascript
Bootstrap教程JS插件滚动监听学习笔记分享
May 18 Javascript
JavaScript的String字符串对象常用操作总结
May 26 Javascript
Vue.js第二天学习笔记(vue-router)
Dec 01 Javascript
a标签置灰不可点击的实现方法
Feb 06 Javascript
基于mpvue的小程序项目搭建的步骤
May 22 Javascript
vue通过style或者class改变样式的实例代码
Oct 30 Javascript
JSONP 的原理、理解 与 实例分析
May 16 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
各种咖啡的英文名子是什么
2021/03/03 新手入门
解析dedeCMS验证码的实现代码
2013/06/07 PHP
PHP中使用数组指针函数操作数组示例
2014/11/19 PHP
PHP使用mysqli操作MySQL数据库的简单方法
2017/02/04 PHP
thinkPHP5.0框架API优化后的友好性分析
2017/03/17 PHP
redis+php实现微博(三)微博列表功能详解
2019/09/23 PHP
用js实现table单元格高宽调整,兼容合并单元格(兼容IE6、7、8、FF)实例
2013/06/25 Javascript
深入理解JavaScript系列(35):设计模式之迭代器模式详解
2015/03/03 Javascript
JavaScript从数组中删除指定值元素的方法
2015/03/18 Javascript
简介JavaScript中strike()方法的使用
2015/06/08 Javascript
Bootstrap导航栏各元素操作方法(表单、按钮、文本)
2015/12/28 Javascript
利用CSS3在Angular中实现动画
2016/01/15 Javascript
jquery 判断selection range 是否在容器中的简单实例
2016/08/02 Javascript
基于jQuery实现淡入淡出效果轮播图
2020/07/31 Javascript
Vue.js实战之组件的进阶
2017/04/04 Javascript
element-ui循环显示radio控件信息的方法
2018/08/24 Javascript
vuejs 制作背景淡入淡出切换动画的实例
2018/09/01 Javascript
使用nodejs分离html文件里的js和css详解
2019/04/12 NodeJs
JS实现盒子拖拽效果
2020/02/06 Javascript
在vue中配置不同的代理同时访问不同的后台操作
2020/09/11 Javascript
如何实现vue的tree组件
2020/12/03 Vue.js
[50:59]2018DOTA2亚洲邀请赛 4.7 总决赛 LGD vs Mineski第四场
2018/04/10 DOTA
python通过floor函数舍弃小数位的方法
2015/03/17 Python
详解Django中Request对象的相关用法
2015/07/17 Python
Python检测网站链接是否已存在
2016/04/07 Python
Python正则表达式经典入门教程
2017/05/22 Python
Python中关于Sequence切片的下标问题详解
2017/06/15 Python
Python中那些 Pythonic的写法详解
2019/07/02 Python
Python实现FTP文件传输的实例
2019/07/07 Python
python 解决Windows平台上路径有空格的问题
2020/11/10 Python
快速创建python 虚拟环境
2020/11/28 Python
给朋友的道歉信
2014/01/09 职场文书
事业单位请假制度
2014/01/13 职场文书
68句权威创业名言
2019/08/26 职场文书
vue基于Teleport实现Modal组件
2021/05/31 Vue.js
python DataFrame中stack()方法、unstack()方法和pivot()方法浅析
2022/04/06 Python