1.可以实现Vue移动端和PC端的响应式布局适配
实现方法:通过 postcss-px-to-viewport 来自动将我们开发时的px单位计算转换为vw/rem视口单位,完成响应式布局 。
安装插件
npm安装
npm install postcss-px-to-viewport -S
npm安装
npm install postcss-px20px -S
npm安装
npm install postcss-px20px -S
PC端适配,在项目根目录下创建 postcss.config.js 配置文件
module.exports = {
plugins: {
'postcss-px-to-viewport': {
unitToConvert: 'px', // 需要转换的单位,默认为"px"
viewportWidth: 1920, // 设计稿的视口宽度
unitPrecision: 3, // 单位转换后保留的精度
propList: ['*'], // 能转化为vw的属性列表
viewportUnit: 'rem', // 希望使用的视口单位
fontViewportUnit: 'rem', // 字体使用的视口单位
selectorBlackList: [], // 需要忽略的CSS选择器,不会转为视口单位,使用原有的px等单位。
minPixelValue: 1, // 设置最小的转换数值,如果为1的话,只有大于1的值会被转换
mediaQuery: true, // 媒体查询里的单位是否需要转换单位
replace: true, // 是否直接更换属性值,而不添加备用属性
exclude: [/node_modules/, /LargeScreen/], // 忽略某些文件夹下的文件或特定文件,例如 'node_modules' 下的文件,数组中写正则
include: undefined, // 如果设置了include,那将只有匹配到的文件才会被转换
landscape: false, // 是否添加根据 landscapeWidth 生成的媒体查询条件 @media (orientation: landscape)
landscapeUnit: 'vw', // 横屏时使用的单位
landscapeWidth: 1920, // 横屏时使用的视口宽度
},
},
};
移动端适配,也是在根目录下创建 postcss.config.js 配置文件,不过配置内容要改变一下。
在写项目的时候,会用到第三方ui组件库,比如vant…,此时你会发现vant组件的尺寸会小一半,那是因为vant官方是用375设计稿,你用的是750,动态判断就好。
下面代码的作用主要是用来判断读取的是否是ui组件库ant-design-vue的文件,如果是,视口的宽度就设置为375,其他的文件则按照ui稿的宽度750
const path = require('path')
module.exports = ({ file }) => {
const designWidth = file.dirname.includes(
path.join('node_modules', 'ant-design-vue')
)
? 375
: 750
return {
plugins: {
autoprefixer: {}, // 用来给不同的浏览器自动添加相应前缀,如-webkit-,-moz-等等
'postcss-px-to-viewport': {
unitToConvert: 'px', // 要转化的单位
viewportWidth: designWidth, // UI设计稿的宽度
unitPrecision: 6, // 转换后的精度,即小数点位数
propList: ['*'], // 指定转换的css属性的单位,*代表全部css属性的单位都进行转换
viewportUnit: 'vw', // 指定需要转换成的视窗单位,默认vw
fontViewportUnit: 'vw', // 指定字体需要转换成的视窗单位,默认vw
selectorBlackList: [], // 指定不转换为视窗单位的类名,
minPixelValue: 1, // 默认值1,小于或等于1px则不进行转换
mediaQuery: true, // 是否在媒体查询的css代码中也进行转换,默认false
exclude: [], // 设置忽略文件,用正则做目录名匹配
landscape: false, // 是否处理横屏情况
// replace: true, // 是否转换后直接更换属性值
},
},
}
}
PC端适配,在项目utils目录下创建 pxtorem.js 文件
// rem等比适配配置文件
// 基准大小
const baseSize = 20
// 设置 rem 函数
function setRem () {
// 当前页面宽度相对于 1920宽的缩放比例,可根据自己需要修改。
const scale = 1 //document.documentElement.clientWidth / 1920
// 设置页面根节点字体大小(“Math.min(scale, 2)” 指最高放大比例为2,可根据实际业务需求调整)
document.documentElement.style.fontSize = baseSize * Math.min(scale, 2) + 'px'
}
// 初始化
setRem()
// 改变窗口大小时重新设置 rem
window.onresize = function () {
setRem()
}
将 pxtorem.js 文件引入main.js
import './utils/pxtorem'
在app.vue中配置一下
<template>
<div id="app" ref="newCatalog">
<router-view name="head" ></router-view>
<router-view name="body"></router-view>
<router-view name="foot"></router-view>
</div>
</template>
<script>
export default {
name: 'App',
components: {
},
data() {
return {
scale: ''
}
},
mounted() {
this.setScale()
window.addEventListener('resize', this.setScale)
},
methods: {
getScale() {
const width = window.screen.width
const height = window.screen.height
let ww = window.innerWidth / 1920
let wh = window.innerHeight / 1080
return ww < wh ? ww : wh
},
setScale() {
this.scale = this.getScale()
this.$refs.newCatalog.style.setProperty('--scale', this.scale)
}
}
}
</script>
<style>
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #333333;
min-width: 1200px;
scale: 1;
}
</style>
配置好文件以后,重启项目就行,也可以不用重启,编译一下就行,可以测试一下。
版权声明:本文为qq_1307495原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。