Bootstrap

关于vue在PC端,对不同屏幕进行适配,未使用媒体查询(大小的自适应)的问题(ant-design-vue,element-ui 均可使用)

前言

  前端项目中,难免会遇到这种问题,你根据UI的设计图在本机搭建页面,显示比例或许会是正常的,但是你将页面缩放,或者说,你将页面移植到其他尺寸的屏幕中,显示的UI效果就会变形。

  常规的做法就是进行媒体查询,不过,我目前做的项目量不是很大,想采用一种新的方式进行屏幕的适配

  以下是我个人在 vue 项目中的适配方法,亲测在 使用 ant-design-vueelement-ui 组件库时任然有效。

  不过这个方法无法更改行间样式,例如 element-ui 的 form 组件 的 label 添加行间样式,此时,就无法通过下面的方法进行适配了,所以这个需要自己想办法来解决。

  虽然我们进行了适配,不过在这还是推荐大家写CSS时,使用 rem 作为单位。

接下来就是我 使用的 屏幕适配方法

1. 安装以下两个依赖

npm install postcss-px2rem px2rem-loader --save

2. 在根目录src中新建rem.js等比适配文件 可直接复制以下代码

// rem等比适配配置文件
// 基准大小
const baseSize = 16;
// 设置 rem 函数
function setRem() {
  // 当前页面屏幕分辨率相对于 1280宽的缩放比例,可根据自己需要修改
  const scale = document.documentElement.clientWidth / 1280;
  // 设置页面根节点字体大小(“Math.min(scale, 3)” 指最高放大比例为3,可根据实际业务需求调整)
  document.documentElement.style.fontSize = `${baseSize * Math.min(scale, 3)}px`;
}
// 初始化
setRem();
// 改变窗口大小时重新设置 rem
window.onresize = () => {
  setRem();
};

3. 在main.js中引入适配文件

在这里插入图片描述

4. 修改 vue.config.js

less 不需要复制,只需要复制 postcss 即可

// 引入等比适配插件
const px2rem = require('postcss-px2rem');

// 配置基本大小
const postcss = px2rem({
  // 基准大小 baseSize,需要和rem.js中相同
  remUnit: 16,
});

module.exports = {
  css: {
    loaderOptions: {
      less: {
        javascriptEnabled: true,
      },
      postcss: {
        plugins: [
          postcss,
        ],
      },
    },
  },
};

end

祝你在开发路上越来越顺利

悦读

道可道,非常道;名可名,非常名。 无名,天地之始,有名,万物之母。 故常无欲,以观其妙,常有欲,以观其徼。 此两者,同出而异名,同谓之玄,玄之又玄,众妙之门。

;