美文网首页
Vue.js 移动端适配之 vw 解决方案

Vue.js 移动端适配之 vw 解决方案

作者: 小虾57 | 来源:发表于2021-12-07 10:18 被阅读0次

    H5需要安装
    npm install dsbridge@3.1.4

    npm i postcss-aspect-ratio-mini postcss-px-to-viewport postcss-write-svg postcss-cssnext postcss-viewport-units cssnano --S
    
    npm i cssnano-preset-advanced --save-dev
    

    找到在根目录中的.postcssrc.js,对PostCSS插件进行配置

    module.exports = {
      "plugins": {
        "postcss-import": {},
        "postcss-url": {},
        // to edit target browsers: use "browserslist" field in package.json
        "postcss-write-svg": {
          uft8: false
        },
        "postcss-cssnext": {},
        "postcss-px-to-viewport": {
          viewportWidth: 750, // 视窗的宽度,对应的是我们设计稿的宽度,一般是750
          viewportHeight: 1334, // 视窗的高度,根据750设备的宽度来指定,一般指定1334,也可以不配置
          unitPrecision: 3, // 指定`px`转换为视窗单位值的小数位数(很多时候无法整除)
          viewportUnit: 'vw', // 指定需要转换成的视窗单位,建议使用vw
          selectorBlackList: ['.ignore', '.hairlines'], // 指定不转换为视窗单位的类,可以自定义,可以无限添加,建议定义一至两个通用的类名
          minPixelValue: 1, // 小于或等于`1px`不转换为视窗单位,你也可以设置为你想要的值
          mediaQuery: false // 允许在媒体查询中转换`px`
        },
        "postcss-viewport-units": {},
        "cssnano": {
          preset: "advanced",
          autoprefixer: false, // 和cssnext同样具有autoprefixer,保留一个
          "postcss-zindex": false
        }
      }
    }
    

    在 index.html 中引入js 解决兼容问题

    <script src="//g.alicdn.com/fdilab/lib3rd/viewport-units-buggyfill/0.6.2/??viewport-units-buggyfill.hacks.min.js,viewport-units-buggyfill.min.js"></script>
    <script>
      window.onload = function () { 
        window.viewportUnitsBuggyfill.init({ hacks: window.viewportUnitsBuggyfillHacks });
      }
    </script>
    

    相关文章

      网友评论

          本文标题:Vue.js 移动端适配之 vw 解决方案

          本文链接:https://www.haomeiwen.com/subject/jivoxrtx.html