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 相关文章推荐
actionscript与javascript的区别
May 25 Javascript
Javascript开发之三数组对象实例介绍
Nov 12 Javascript
jQuery实现跨域iframe接口方法调用
Mar 14 Javascript
谈谈Jquery ajax中success和complete有哪些不同点
Nov 20 Javascript
Bootstrap每天必学之按钮(一)
Nov 24 Javascript
jQuery实现图片局部放大镜效果
Mar 17 Javascript
jQuery代码实现图片墙自动+手动淡入淡出切换效果
May 09 Javascript
jQuery实现鼠标经过时高亮,同时其他同级元素变暗的效果
Sep 18 Javascript
Mui使用jquery并且使用点击跳转新窗口的实例
Aug 19 jQuery
JS实现遍历不规则多维数组的方法
Mar 21 Javascript
JS返回页面时自动回滚到历史浏览位置
Sep 26 Javascript
angularjs1.X 重构controller 的方法小结
Aug 15 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采集神器cURL使用方法详解
2016/02/19 PHP
用javascript实现的图片马赛克后显示并切换加文字功能
2007/04/21 Javascript
关于锚点跳转及jQuery下相关操作与插件
2012/10/01 Javascript
Jquery实现点击切换图片并隐藏显示内容(2种方法实现)
2013/04/11 Javascript
Jquery validation remote 验证的缓存问题解决方法
2014/03/25 Javascript
node.js中的fs.futimesSync方法使用说明
2014/12/17 Javascript
JS动态修改图片的URL(src)的方法
2015/04/01 Javascript
使用javascript将时间转换成今天,昨天,前天等格式
2015/06/25 Javascript
jquery实现页面虚拟键盘特效
2015/08/08 Javascript
js获取页面及个元素高度、宽度的代码
2016/04/26 Javascript
Node.js下自定义错误类型详解
2016/10/17 Javascript
JS短信验证码倒计时功能的实现(没有验证码,只有倒计时)
2016/10/27 Javascript
JavaScript &amp; jQuery完美判断图片是否加载完毕
2017/01/08 Javascript
微信小程序 缓存(本地缓存、异步缓存、同步缓存)详解
2017/01/17 Javascript
JS中正则表达式全局匹配模式 /g用法详解
2017/04/01 Javascript
在Vue项目中引入JQuery-ui插件的讲解
2019/01/27 jQuery
详解Vue中使用插槽(slot)、聚类插槽
2019/04/12 Javascript
10种JavaScript最常见的错误(小结)
2019/06/21 Javascript
创建与框架无关的JavaScript插件
2020/12/01 Javascript
利用python爬取软考试题之ip自动代理
2017/03/28 Python
深入理解python中sort()与sorted()的区别
2018/08/29 Python
python 求某条线上特定x值或y值的点坐标方法
2019/07/09 Python
Python 如何提高元组的可读性
2019/08/26 Python
Python openpyxl读取单元格字体颜色过程解析
2019/09/03 Python
Tensorflow 多线程设置方式
2020/02/06 Python
python 偷懒技巧——使用 keyboard 录制键盘事件
2020/09/21 Python
python爬虫scrapy图书分类实例讲解
2020/11/23 Python
Pandas直接读取sql脚本的方法
2021/01/21 Python
HTML5实现无刷新修改URL的方法
2019/11/14 HTML / CSS
FC-Moto英国:欧洲最大的摩托车服装和头盔商店之一
2019/08/25 全球购物
int和Integer有什么区别
2013/05/25 面试题
大学生个人总结的自我评价
2013/10/05 职场文书
2015年教师工作总结范文
2015/03/31 职场文书
毕业实习证明范本
2015/06/16 职场文书
2016年度师德标兵先进事迹材料
2016/02/26 职场文书
导游词之鲁迅祖居
2019/10/17 职场文书