导读:
前端项目中,难免会遇到这种问题,你根据UI的设计图在本机搭建页面,显示比例或许会是正常的,但是你将页面缩放,或者说,你将页面移植到其他尺寸的屏幕中,显示的UI效果就会变形。
常规的做法就是进行媒体查询,不过,我目前做的项目量不是很大,想采用一种新的方式进行屏幕的适配
以下是我个人在 vue 项目中的适配方法,亲测在 使用 ant-design-vue 和 element-ui 组件库时仍然有效。
不过这个方法无法更改行间样式,例如 element-ui 的 form 组件 的 label 添加行间样式,此时,就无法通过下面的方法进行适配了,所以这个需要自己想办法来解决。
虽然我们进行了适配,不过在这还是推荐大家写CSS时,使用 rem 作为单位。
接下来就是我 使用的 屏幕适配方法。
1. 安装以下两个依赖
yarn add postcss-px2rem px2rem-loader --save
or
npm install postcss-px2rem px2rem-loader --save-dev
2. 在根目录src中新建torem.js等比适配文件
// rem等比适配配置文件
// 基准大小
const baseSize = 16;
// 设置 rem 函数
function setRem() {
// 当前页面屏幕分辨率相对于 1280宽的缩放比例,可根据自己需要修改
const scale = document.documentElement.clientWidth / 1920;
// 设置页面根节点字体大小(“Math.min(scale, 3)” 指最高放大比例为3,可根据实际业务需求调整)
document.documentElement.style.fontSize = `${baseSize * Math.min(scale, 3)}px`;
}
// 初始化
setRem();
// 改变窗口大小时重新设置 rem
window.onresize = () => {
setRem();
};
3. 在main.js中引入适配文件
4. 修改 vite.config
import { fileURLToPath, URL } from 'node:url'
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
// 引入 postcss-px2rem 插件
import px2rem from 'postcss-px2rem';
// 配置基本大小
const postcss = px2rem({
// 基准大小 baseSize,需要和 torem.js中相同
remUnit: 16,
});
export default defineConfig({
css: {
postcss: {
plugins: [postcss],
},
},
plugins: [
vue(),
],
resolve: {
alias: {
'@': fileURLToPath(new URL('./src', import.meta.url))
}
},
base: './',
})
postcss-px2rem 还有其他一些配置,可以根据需要去postcss-px2rem - npm 按需配置。
以上代码只是为了给大家一个参考,具体如何适配还是要看项目需求和个人理解。