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中的绑定与解绑函数应用示例
Jun 24 Javascript
js 浏览本地文件夹系统示例代码
Oct 24 Javascript
解析Javascript中中括号“[]”的多义性
Dec 03 Javascript
键盘上一张下一张兼容IE/google/firefox等浏览器
Jan 28 Javascript
html的DOM中document对象images集合用法实例
Jan 21 Javascript
分享9点个人认为比较重要的javascript 编程技巧
Apr 27 Javascript
javaScript实现滚动新闻的方法
Jul 30 Javascript
jQuery-1.9.1源码分析系列(十)事件系统之事件体系结构
Nov 19 Javascript
jQuery ajax应用总结
Jun 02 Javascript
解决Node.js使用MySQL出现connect ECONNREFUSED 127.0.0.1:3306的问题
Mar 09 Javascript
Vue列表循环从指定下标开始的多种解决方案
Apr 08 Javascript
原生js实现下拉框选择组件
Jan 20 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
曾在DC漫画界反派角色扮演的演员,谁才是你心目中的小丑之王?
2020/04/09 欧美动漫
PHP合并两个数组的两种方式的异同
2012/09/14 PHP
win7 64位系统 配置php最新版开发环境(php+Apache+mysql)
2014/08/15 PHP
PHP之autoload运行机制实例分析
2014/08/28 PHP
thinkphp中memcache的用法实例
2014/11/29 PHP
php使用memcoder将视频转成mp4格式的方法
2015/03/12 PHP
js版本A*寻路算法
2006/12/22 Javascript
Jquery Ajax学习实例4 向WebService发出请求,返回实体对象的异步调用
2010/03/16 Javascript
ModelDialog JavaScript模态对话框类代码
2011/04/17 Javascript
javascript实现博客园页面右下角返回顶部按钮
2015/02/22 Javascript
js中跨域方法原理详解
2015/07/19 Javascript
Markdown与Bootstrap相结合实现图片自适应属性
2016/05/04 Javascript
Bootstrap modal 多弹窗之叠加显示不出弹窗问题的解决方案
2017/02/23 Javascript
jQuery实现百度登录框的动态切换效果
2017/04/21 jQuery
修改npm全局安装模式的路径方法
2018/05/15 Javascript
js+css实现扇形导航效果
2020/08/18 Javascript
解决antd的Form组件setFieldsValue的警告问题
2020/10/29 Javascript
[49:02]KG vs Infamous 2019国际邀请赛淘汰赛 败者组BO1 8.20.mp4
2020/07/19 DOTA
Python打印scrapy蜘蛛抓取树结构的方法
2015/04/08 Python
浅谈numpy中linspace的用法 (等差数列创建函数)
2017/06/07 Python
获取Django项目的全部url方法详解
2017/10/26 Python
Python3计算三角形的面积代码
2017/12/18 Python
Ubuntu16.04/树莓派Python3+opencv配置教程(分享)
2018/04/02 Python
Python 隐藏输入密码时屏幕回显的实例
2019/02/19 Python
Python学习笔记之错误和异常及访问错误消息详解
2019/08/08 Python
Pycharm中切换pytorch的环境和配置的教程详解
2020/03/13 Python
基于Python爬取京东双十一商品价格曲线
2020/10/23 Python
应届生服装设计自我评价
2013/09/20 职场文书
事假请假条范文
2014/04/11 职场文书
党员公开承诺书内容
2014/05/20 职场文书
煤矿安全知识竞赛活动总结
2014/07/07 职场文书
民主评议政风行风活动心得体会
2014/10/29 职场文书
工程催款通知书
2015/04/17 职场文书
2015年迎新晚会策划书
2015/07/16 职场文书
致创业的您:这类人不适合餐饮创业
2019/08/19 职场文书
vue如何实现关闭对话框后刷新列表
2022/04/08 Vue.js