0


Vue2实现响应式布局方案

1.可以实现Vue移动端和PC端的响应式布局适配

实现方法:通过 postcss-px-to-viewport 来自动将我们开发时的px单位计算转换为vw视口单位,完成响应式布局 。

安装插件

npm安装
npm install postcss-px-to-viewport -S 
yarn安装
yarn add postcss-px-to-viewport -S 

PC端适配,在项目根目录下创建 postcss.config.js 配置文件

module.exports ={plugins:{'postcss-px-to-viewport':{unitToConvert:'px',// 需要转换的单位,默认为"px"viewportWidth:1920,// ui设计稿的视口宽度unitPrecision:5,// 单位转换后保留的精度propList:['*'],// 能转化为vw的属性列表,不需要转换的css样式属性可以写在propList['*']里面,在前面加上!号即可,比如propList['*','!width'],这表示css所有的属性都可以单位转换,除了width不转换。viewportUnit:'vw',// 希望使用的视口单位fontViewportUnit:'vw',// 字体使用的视口单位selectorBlackList:[],// 需要忽略的CSS选择器,不会转为视口单位,使用原有的px等单位,比如selectorBlackList: ['box'],box这个类名下使用的所有css属性都不会被转换单位。minPixelValue:1,// 设置最小的转换数值,如果为1的话,只有大于1的值会被转换mediaQuery:false,// 媒体查询里的单位是否需要转换单位replace:true,//  是否直接更换属性值,而不添加备用属性exclude:undefined,// 忽略某些文件夹下的文件或特定文件,例如 '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:750return{plugins:{autoprefixer:{},// 用来给不同的浏览器自动添加相应前缀,如-webkit-,-moz-等等'postcss-px-to-viewport':{unitToConvert:'px',// 要转化的单位viewportWidth: designWidth,// UI设计稿的宽度unitPrecision:6,// 转换后的精度,即小数点位数propList:['*'],// 指定转换的css属性的单位,*代表全部css属性的单位都进行转换viewportUnit:'vw',// 指定需要转换成的视窗单位,默认vwfontViewportUnit:'vw',// 指定字体需要转换成的视窗单位,默认vwselectorBlackList:[],// 指定不转换为视窗单位的类名,minPixelValue:1,// 默认值1,小于或等于1px则不进行转换mediaQuery:true,// 是否在媒体查询的css代码中也进行转换,默认falseexclude:[],// 设置忽略文件,用正则做目录名匹配landscape:false,// 是否处理横屏情况// replace: true, // 是否转换后直接更换属性值},},}}

配置好文件以后,重启项目就行,也可以不用重启,编译一下就行,可以测试一下,用一张全屏图片,给图片设置宽高,缩小放大浏览器窗口,图片跟着视口变化就成功了。

仔细看上面的配置信息,需要的进行配置。

标签: ui javascript 前端

本文转载自: https://blog.csdn.net/AKindofo/article/details/127105162
版权归原作者 一杆老狙 所有, 如有侵权,请联系我们删除。

“Vue2实现响应式布局方案”的评论:

还没有评论