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 通用简单的table选项卡实现
May 07 Javascript
新浪微博字数统计 textarea字数统计实现代码
Aug 28 Javascript
js动态创建、删除表格示例代码
Aug 07 Javascript
JavaScript中的prototype和constructor简明总结
Apr 05 Javascript
jquery精度计算代码 jquery指定精确小数位
Feb 06 Javascript
关于vue-router路径计算问题
May 10 Javascript
angular2组件中定时刷新并清除定时器的实例讲解
Aug 31 Javascript
vue-router实现编程式导航的代码实例
Jan 19 Javascript
基于javascript处理nginx请求过程详解
Jul 07 Javascript
JS pushlet XMLAdapter适配器用法案例解析
Oct 16 Javascript
js实现简单的轮播图效果
Dec 13 Javascript
js删除对象中的某一个字段的方法实现
Jan 11 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静态文件生成类实例
2014/11/29 PHP
浅谈laravel aliases别名的原理
2019/10/24 PHP
laravel 框架结合关联查询 when()用法分析
2019/11/22 PHP
jquery监听div内容的变化具体实现思路
2013/11/04 Javascript
jQuery及JS实现循环中暂停的方法
2015/02/02 Javascript
javascript中new关键字详解
2015/12/14 Javascript
4种JavaScript实现简单tab选项卡切换的方法
2016/01/06 Javascript
简单解析JavaScript中的__proto__属性
2016/05/10 Javascript
再谈Javascript中的基本类型和引用类型(推荐)
2016/07/01 Javascript
vue.js 添加 fastclick的支持方法
2018/08/28 Javascript
ElementUI Tag组件实现多标签生成的方法示例
2019/07/08 Javascript
微信小程序 拍照或从相册选取图片上传代码实例
2019/08/28 Javascript
微信小程序利用云函数获取手机号码
2019/12/17 Javascript
python实现将汉字转换成汉语拼音的库
2015/05/05 Python
Python递归函数定义与用法示例
2017/06/02 Python
python安装numpy&amp;安装matplotlib&amp; scipy的教程
2017/11/02 Python
python 定时修改数据库的示例代码
2018/04/08 Python
Django框架会话技术实例分析【Cookie与Session】
2019/05/24 Python
python+selenium 点击单选框-radio的实现方法
2019/09/03 Python
浅析使用Python搭建http服务器
2019/10/27 Python
pytorch实现MNIST手写体识别
2020/02/14 Python
基于css3实现漂亮便签样式
2013/03/18 HTML / CSS
韩国著名的在线综合购物网站:Akmall
2016/08/07 全球购物
JACK & JONES英国官方网站:欧洲领先的男装生产商
2017/09/27 全球购物
美国最大的旗帜经销商:Carrot-Top
2018/02/26 全球购物
如何判断计算机可能已经中马
2013/03/22 面试题
大学生村官工作感言
2014/01/10 职场文书
大学生涯自我鉴定
2014/01/16 职场文书
幼儿园家长评语
2014/02/10 职场文书
竞选班干部演讲稿500字
2014/08/20 职场文书
建筑节能汇报材料
2014/08/22 职场文书
个人借款协议书范本
2014/11/17 职场文书
2014年电厂工作总结
2014/12/04 职场文书
2014年林业工作总结
2014/12/05 职场文书
高端收音机+蓝牙音箱,JBL TUNER FM带收音蓝牙音箱评测
2021/04/24 无线电
如何搭建 MySQL 高可用高性能集群
2021/06/21 MySQL