美文网首页前端行者
[New]Vue项目使用vw实现移动端适配教程

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

作者: 是ADI呀 | 来源:发表于2018-01-27 10:43 被阅读1968次
    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进行移动端项目开发啦!

    相关文章

      网友评论

      • 4adea5e90b7b:容器字体大小也用vw吗,会不会不太好
      • 独孤久见:postcss-write-svg 实现Retina屏1像素边框你这里是不是也没有成功,我弄了好久就是1px线还是很粗
      • 60bae969e998:有个问题,有没有办法让vw vh大于一定值后不随屏幕变化了?
        就像rem方案一样 媒体查询min-width 设置html最大font-size ,使viewport有一个最大宽度,并水平居中
        60bae969e998:@大象无痕 是的 就是想有没有其他变通的方法实现这个效果 不然为了大屏不至于太大没法看 只能改成rem方案 只把vw设为html fontsize,但我这之前是px 也是用大漠老师这个插件自动转换 再改也比较麻烦 也还想继续用这些插件
        是ADI呀:rem方案是根据js动态计算的可以修改换算方式。vw是浏览器实际显示内容的区域,通过媒体查询来实现相似效果会比较麻烦。
      • 叫我文博就行:您好,使用vue-cli新创建的项目, 按照作者的步骤操作之后, dev环境一点问题都没有, 很完美. 在我准备打包部署build的时候, npm报出了错误.
        building for production...Error processing file: static/css/app.8756b87dc2597042448726acb46e29d7.css
        (node:27404) UnhandledPromiseRejectionWarning: Error: Option safe was removed. Use parser: require("postcss-safe-parser")
        …………
        (node:27404) UnhandledPromiseRejectionWarning: Unhandled promise rejection. This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). (rejection id: 2)
        (node:27404) [DEP0018] DeprecationWarning: Unhandled promise rejections are deprecated. In the future, promise rejections that are not handled will terminate the Node.js process with a non-zero exit code.

        请问这种情况怎么解决?:clap:
        在线等, 急急急
        是ADI呀:@大象无痕 https://www.npmjs.com/package/postcss-safe-parser
        是ADI呀:@叫我文博就行 安装这个试一下
        叫我文博就行:除了作者本页提到的插件以外, 没有安装其他插件
      • 1e44d344510f:请问,行间的样式无法转换,有什么解决方法?
        是ADI呀:行内样式应该时已经写好dom结构了,sublime有个px2rem插件可以ctrl加z转化为rem
      • 阿康_b943:你好,请问有在生产上使用吗
        是ADI呀:@阿康_b943 这边工作上都是在写小程序没写移动端,你可以试试,之前用rem方案的项目可以平滑过渡过来,大漠大佬有写过这个博客
      • 是ADI呀:有不够详细不够清晰的地方call me:heart:
        是ADI呀:@梁铭枫 这个我的处理方式是不使用px2rem换种插件 ,我现在在用的是vscode的px to rem插件
        梁铭枫:install的时候报404 Not Found: Viewport@latest
        梁铭枫:好像自动转换只支持style里面的css?同时好像会影响第三方库

      本文标题:[New]Vue项目使用vw实现移动端适配教程

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