[分享] [New]Vue项目使用vw实现移动端适配教程

268223-106.jpg

2018年1月25日 11:58:01 最新的大漠老师移动端适配方案,
使用这套方案可以取代flexible.js
首先建议读者先去学习大漠老师的这篇文章,看完能有大大的收获
如何在Vue项目中使用vw实现移动端适配


正文开始

使用vue-cli新建项目

vue init webpack vue-demo
cd vue-demo
npm run dev

安装依赖

  • 复制以下代码:
npm i postcss-aspect-ratio-mini postcss-px-to-viewport postcss-write-svg postcss-cssnext postcss-viewport-units cssnano cssnano-preset-advanced --S
  • 复制进行 postcssrc.js 配置
    .postcssrc.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,
      unitPrecision: 3,
      viewportUnit: 'vw',
      selectorBlackList: ['.ignore', '.hairlines'],
      minPixelValue: 1,
      mediaQuery: false
    },
    "postcss-viewport-units": {},
    "cssnano": {
      preset: "advanced",
      autoprefixer: false,
      "postcss-zindex": false
    }
  }
}

各插件的功能:


postcss-px-to-viewport : 将项目中的px转化为vw

"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` 
}
  • 容器适配,可以使用vw
  • 文本的适配,可以使用vw
  • 大于1px的边框、圆角、阴影都可以使用vw
  • 内距和外距,可以使用vw

postcss-px-to-viewport文档


postcss-write-svg 实现Retina屏1像素边框
首先记得在heade头加入
<meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,minimum-scale=1,user-scalable=no" />

实例不成功,换插件实现吧

方式一:

方式二:


最重要的 降级处理
使用 Viewport Units Buggyfill 插件
在vue项目的index.html文件head标签添加引用
<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文件body标签后添加以下代码

<script>
  // vw兼容性处理viewport-units-buggyfill
    window.onload = function () {
      window.viewportUnitsBuggyfill.init({ hacks: window.viewportUnitsBuggyfillHacks });
      //以下代码用户测试
      // var winDPI = window.devicePixelRatio;
      // var uAgent = window.navigator.userAgent;
      // var screenHeight = window.screen.height;
      // var screenWidth = window.screen.width;
      // var winWidth = window.innerWidth;
      // var winHeight = window.innerHeight;
      // console.log("Windows DPI:" + winDPI + ";\ruAgent:" + uAgent + ";\rScreen Width:" +
      //   screenWidth + ";\rScreen Height:" + screenHeight + ";\rWindow Width:" + winWidth +
      //   ";\rWindow Height:" + winHeight)
    }
  </script>

最后做个对img兼容处理,在全局添加(在main.js 用 Import '@/common/index.css')

img {
  content: normal !important;
}
这样就可以用vw进行移动端项目开发啦!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 响应式布局的实现依靠媒体查询( Media Queries )来实现,选取主流设备宽度尺寸作为断点针对性写额外的样...
    iyimao阅读 543评论 0 0
  • 1、垂直对齐 如果你用CSS,则你会有困惑:我该怎么垂直对齐容器中的元素?现在,利用CSS3的Transform,...
    kiddings阅读 3,215评论 0 11
  • 當一個你愛的人,本性中不被你所理解的部分爆發出來,你是會限制她的本性,還是會理解並且容忍呢。 多了雜念之後零變成一...
    谷雨阿阅读 288评论 0 0
  • 每一天 看着你们笑盈盈的亮晶晶的双眼 抚摸着你们滑滑的嫩嫩的脸颊 闻着你们香香的暖暖的奶香味 拉着你们小小的可爱的...
    深浅慧阅读 232评论 0 0
  • 前端是啥,他们要做什么事情呢,工作流程? 理解: 前:代表与人直接打交道的这部分,包括界面的展现,与用户的交互等端...
    Sheldon_Yee阅读 390评论 0 3