移动端适配方案

1、适配方案: amfe-flexible 和 postcss-pxtorem

amfe-flexible 是配置可伸缩布局方案,主要是将 1rem 设为 viewWidth/10。

postcss-pxtorem是postcss的插件,用于将像素单元生成rem单位。

2、如何使用和配置?

1、安装 amfe-flexible 和 postcss-pxtorem

1

2

npm install amfe-flexible --save

npm install postcss-pxtorem --save

2、安装完成后,main.js中引入

1

import 'amfe-flexible';

3、然后postcss-pxtorem 配置步骤

配置postcss-pxtorem,可在vue.config.js、.postcssrc.js、postcss.config.js其中之一配置,权重从左到右降低,没有则新建文件,只需要设置其中一个即可:

为了方便 我是在 vue.config.js 配置的代码配置如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

module.exports = {

    //...其他配置

    css: {

        loaderOptions: {

            postcss: {

                plugins: [

                    require('postcss-pxtorem')({

                        rootValue: 37.5,

                        propList: ['*']

                    })

                ]

            }

        }

    },

}

在.postcssrc.js或postcss.config.js中配置如下:

1

2

3

4

5

6

7

8

module.exports = {

    "plugins": {

        'postcss-pxtorem': {

            rootValue: 37.5,

            propList: ['*']

        }

    }

}

注意点:
1、rootValue根据设计稿宽度除以10进行设置,这边假设设计稿为375,即rootValue设为37.5;
2、propList是设置需要转换的属性,这边*为所有都进行转换。

通过以上配置我们就可以在项目使用了。

比如项目中我们这样写:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

.login-form {

    width90%;

    positionabsolute;

    top50%;

    left50%;

    transform: translate(-50%-50%);

    background-color#fff;

    padding20px;

    box-sizing: border-box;

    border-radius: 10px;

    .title {

      positionabsolute;

      top-50px;

      font-size24px;

      color#fff;

      left0;

      right0;

      text-aligncenter;

    }

  }

那我们代码的产出就是下面这样的 ,插件帮我们自动转换单位。

1

2

3

4

5

6

7

8

9

10

11

login-wraper .login-form {

    width90%;

    positionabsolute;

    top50%;

    left50%;

    transform: translate(-50%,-50%);

    background-color#fff;

    padding: .53333rem; // 注意这个就是转换后的单位

    box-sizing: border-box;

    border-radius: .26667rem;  // 注意这个就是转换后的单位

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值