zoukankan      html  css  js  c++  java
  • 【前端适配】vw单位移动端适配方案

    近些年移动端的强势崛起,导致移动端适配越来越重要,个人之前一直使用的是rem进行适配,但是发现并不是非常完美,给力的是大漠老师写了一篇《如何在Vue项目中使用vw实现移动端适配》,比较完美的解决了适配问题,下面是自己动手搭建后的一些整理。

    创建项目

    //vue-cli 3.0+ 版本
    vue init webpack vue-vw-demo
    cd  vue-vw-demo

    安装必要插件

    npm i postcss-aspect-ratio-mini postcss-px-to-viewport postcss-write-svg postcss-cssnext postcss-viewport-units cssnano postcss-import postcss-url --s

    配置根目录下的postcss.config.js

    module.exports = {
      "plugins": {
        "postcss-import": {},
        "postcss-url": {},
        "postcss-aspect-ratio-mini": {},
        "postcss-write-svg": { utf8: 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,
          "postcss-zindex": false
         }
      }
    }

    兼容 vw(index.html引入)

    //在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>
    //在index.html中调用viewport-units-buggyfill
    <script> 
      window.onload = function () { 
        window.viewportUnitsBuggyfill.init({ 
          hacks: window.viewportUnitsBuggyfillHacks 
        });
      } 

    </script>

    配置scss

    npm install node-sass --save-dev
    npm install sass-loader --save-dev

    ./build/webpack.base.config.js添加如下配置

    module.exports = {
      module: {
        rules: [
          ...
          {
            test: /.scss$/,
            loaders: ["style", "css", "sass"]
          }
        ]
      }
    }

    Tip:组件中使用,记得加上lang='scss'

            设计稿20px这里写两倍(40px)

    最后运行cnpm run dev启动项目,最后还是推荐看一看大漠老师的原文《如何在Vue项目中使用vw实现移动端适配》,原文写的很清楚,对各个插件也进行了解释,相信你看了会有收获。

  • 相关阅读:
    执行超过1个小时的SQL语句
    非周一回写销售预测
    openLDAP
    Windows下使用性能监视器监控SqlServer的常见指标
    ORA-01720: grant option does not exist for 'xxx.xxxx' (ORA-01720 ‘XXX’ 不存在授权选项)
    117 FP页面无法查看 此错误是JDK8.0.0.0版本的一个BUG,会导致工单重复回写,
    KPI
    Quatrz + Spring
    windows 脚本
    Spring集成Redis
  • 原文地址:https://www.cnblogs.com/xiaohuizhang/p/11959082.html
Copyright © 2011-2022 走看看