vue-cli4-vw适配总结

ps已经很久没有发表博客了,最近一些知识点的整理已经上传到了githubalwaysBeReady项目,如果想查看最新知识点整理可以直接访问github项目地址,欢迎点击star,或者提issue补充内容,指正总结中的错误点等。

参考资料

移动端适配方案:基于flexible库的成熟方案和基于vw的新方案
cssnano

autoprefixer

一个很好的例子autoprefixer,这个转换通过删除陈旧的带有特定厂商前缀的属性从而修改了CSS语义。为了保证转换的安全,你的browserslist 配置必须反映出你的站点所选择支持的浏览器。

相关依赖

  • cssnano

    cssnano 就是这样的一个缩减器,它使基于 Node.js 开发的。cssnano 是一个 PostCSS 插件,可以添加到你的构建流程中,用于确保最终生成的 用于生产环境的 CSS 样式表文件尽可能的小

  • cssnano-preset-advanced

    使用高级转换,默认情况下,高级转换不会与cssnano捆绑在一起的,因此你需要在安装cssnano时一同安装相应的预设(preset)

  • postcss-aspect-radio-mini

    用来处理元素容器宽高比

  • postcss-cssnext

    该插件可以让我们使用css未来的特性,其会对这些特性做相关的兼容性处理。

  • postcss-px-to-viewport

    插件主要用来把px单位转换为vw、vh、vmin或者vmax这样的视窗单位,也是vw适配方案的核心插件之一。

  • postcss-px-to-viewport-opt

    改良版postcss-px-to-viewport

  • postcss-viewport-units

    主要是给CSS的属性添加content的属性,配合viewport-units-buggyfill库给vw、vh、vmin和vmax做适配的操作。

  • postcss-write-svg

    该插件主要用来处理移动端1px的解决方案。

一、使用方式

安装插件

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

添加配置文件postcss.config.js

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

二、引入Viewport Units Buggyfill

参考链接
作用:对于不支持VW单位的机型降级处理。

使用方式:1.在HTML文件中引入这两个文件。

<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>

2.在HTML文件中调用viewport-units-buggyfill

<!--使用viewport-units-buggyfill解决个别手机不支持vw-->
<script>
window.onload = function () {
  window.viewportUnitsBuggyfill.init({
    hacks: window.viewportUnitsBuggyfillHacks
  });
}
</script>

三、项目配置自动引入全局scss文件

注:在每个组件中引入的形式如@import './assets/css/style.scss';,这样每个组件都要引入一次很麻烦。所以考虑要全局引入,在main.ts引入import './assets/css/common.scss是无效的,当组件在使用common.scss下的变量的时候,会提示undefined

正确配置方式:在vue.config.js文件使得每个vue文件自动引入全局scss文件。参考资料
vue.config.js配置

// vue.config.js
module.exports = {
css: {
  loaderOptions: {
    scss: {
      prependData: `@import "~@/assets/css/style.scss";` 
    },
  } 
}
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值