• 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
        : 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, // 是否转换后直接更换属性值
          },
        },
      }
    }
    '
    运行

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

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

  • 相关阅读:
    windows server 2012搭建ftp站点服务器,新建ftp用户,设置ftp文件夹权限,通过ftp实现文件远程备份、异地备份
    【C++】C向C++的知识过度(上)
    2022团体程序设计天梯赛L1
    ThingsBoard 开源物联网平台
    Visual C++ 2010开发的程序在其它电脑上运行提示“找不到MSVCR100D.dll”原因及解决
    C++二叉树
    【Linux】《Linux命令行与shell脚本编程大全 (第4版) 》笔记-Chapter1-初始 Linux Shell
    相控阵天线有源驻波测试
    算法DAY66
    美团三年,总结的10条血泪教训
  • 原文地址:https://blog.csdn.net/AKindofo/article/details/127105162