Vue实现rem自适应布局,无需安装插件,代码简单

47 篇文章 70 订阅
4 篇文章 9 订阅

🤵 作者coderYYY
🧑 个人简介:前端程序媛,目前主攻web前端,后端辅助,其他技术知识也会偶尔分享🍀欢迎和我一起交流!🚀(评论和私信一般会回!!)
👉 个人专栏推荐《前端项目教程以及代码》

Vue实现rem自适应布局,无需安装插件,跟随窗口变化,使用场景一般为echarts数据可视化大屏

✨一、前言

  • rem自适应布局其实就是以html的字体大小作为相对单位,比如html的字体大小为16px,那么1rem=16px
  • 之前用过rem的npm插件,但是效果都不尽人意,且html的字体只能写死
  • 本文是通过在Vue中监听windowresize事件,动态设置htmlfont-size,以达到自适应效果

🚩二、具体实现

代码比较简单,直接送上:

 data() {
    return {
      whei: 0,// 窗口宽度
    };
  },

  mounted() {
  
    this.whei = window.innerWidth;
    this.setHtmlFontSize();
	// 监听窗口变化 
    window.addEventListener("resize", this.setHtmlFontSize);
  },

  methods: {
    /* 动态设置html字体大小 */
    setHtmlFontSize() {
      this.whei = window.innerWidth;
      document.querySelector("html").style.fontSize = this.whei / 20 + "px";
    },
  }

css中可以直接使用rem作为单位了:

.pie{
    width: 3.5rem;
    height: 3.5rem;
}

这样就能在Vue中完美实现rem自适应,且布局不会乱,个人最常用于Vue+echarts数据可视化大屏中,后续专栏也会更新模板,感兴趣的可以订阅

【专栏】Vue+Echarts数据可视化大屏通用模板

在这里插入图片描述

  • 15
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
Vue项目中实现自适应布局有多种方案。其中一种常用的方案是使用postcss-px-to-viewport插件。该插件可以将以像素为单位的样式属性转化为相应的视窗单位,从而实现自适应效果。 首先,你需要在项目的开发环境中安装postcss-px-to-viewport插件。可以使用npm命令进行安装:npm i postcss-px-to-viewport -D。 然后,在项目根目录下创建一个.postcssrc.js文件,并添加以下配置: ```javascript module.exports = { plugins: { autoprefixer: {}, "postcss-px-to-viewport": { unitToConvert: "px", viewportWidth: 750, unitPrecision: 6, propList: ["*"], viewportUnit: "vw", fontViewportUnit: "vw", selectorBlackList: [], minPixelValue: 1, mediaQuery: true, exclude: [], landscape: false } } }; ``` 这个配置文件指定了要转换的单位为像素(px),UI设计稿的宽度为750,转换后的精度为6位小数,将转换所有css属性的单位为vw,字体也使用vw作为单位,不排除任何类名,设置最小像素值为1,在媒体查询中也进行转换,不进行直接替换属性值,不排除任何文件夹,不处理横屏情况。 安装完成并配置好后,插件将会在代码编译时自动将样式属性进行转换,实现自适应布局效果。 需要注意的是,如果你在vant项目中使用这个插件,可能会改变vant的样式。为了解决这个问题,有两种解决方式。一种是将设计稿大小改为375,因为vant是以375为参考的。另一种是在配置文件中添加以下内容: ```javascript module.exports = { plugins: { autoprefixer: {}, "postcss-px2rem-exclude": { remUnit: 75, exclude: /node_modules/i, selectorBlackList: ["van-"] } } }; ``` 以上配置中,remUnit设定为75,排除了node_modules文件夹下的样式文件,同时排除了以"van-"开头的类名,这样就可以避免vant框架相关组件或某些样式受到rem的影响。 使用postcss-px-to-viewport插件可以方便地实现Vue项目中的自适应布局。根据你的具体需求和项目情况,选择合适的配置方式来达到自适应效果。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [vue自适应布局3种方法](https://blog.csdn.net/qq_28512043/article/details/107949915)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [vue自适应布局](https://blog.csdn.net/weixin_46396187/article/details/108060145)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

coderYYY

请简单粗暴地爱我,一元一元的赏

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值