#postcss配置
#1、安装依赖
pnpm install postcss postcss-pxtorem autoprefixer -D#2、postcss.config.js
export default {
plugins: {
autoprefixer: {},
'postcss-pxtorem': {
rootValue: 16,
propList: ['*', '!font-size'],
selectorBlackList: ['.no-rem'],
unitPrecision: 1,
replace: true,
mediaQuery: false,
minPixelValue: 1,
exclude: /node_modules/i,
},
},
}
#3、rem.ts
function setRem() {
const baseWidth = 1920
const baseFontSize = 16
const currentWidth = document.documentElement.clientWidth || window.innerWidth
const scale = currentWidth / baseWidth
const fontSize = Math.max(10, baseFontSize * scale)
document.documentElement.style.fontSize = `${fontSize}px`
}
setRem()
window.onresize = function () {
setRem()
}#4、main.ts配置
import { createApp } from 'vue'
import pinia from './stores'
import Antd from 'ant-design-vue'
import './styles/main.css'
import './utils/rem'
import 'ant-design-vue/dist/reset.css'
import App from './App.vue'
import router from './router'
const app = createApp(App)
app.use(pinia)
app.use(router)
app.use(Antd)
app.mount('#app')
