Vue进阶(幺陆捌):前端用户体验提升(三)自定义布局

举报
SHQ5785 发表于 2021/02/20 09:37:34 2021/02/20
【摘要】 使用 `vw/vh` 布局实现自适应优于其他方案,能够完美的解决调屏幕自适应问题。

vw/vh

`vw/vh`单位可以根据电脑浏览器自适应。
- `vw` —— 视口宽度的 1/100;
- `vh` —— 视口高度的 1/100

在pc端,视口宽高就是浏览器的宽高;

 vw/vh定义

`css3`中引入了一个新的单位`vw/vh`,与视图窗口有关,`vw`表示相对于视图窗口的宽度,`vh`表示相对于视图窗口高度,除了`vw`和`vh`外,还有`vmin`和`vmax`两个相关的单位。各个单位具体的含义如下:

这里我们发现视窗宽高都是`100vw`/`100vh`,那么vw或者vh,下简称vw,很类似百分比单位。vw和%的区别为:

从对比中我们可以发现,`vw`单位与百分比类似,但确有区别,百分比单位的换算比较困难,这里的`vw`更像"**理想的百分比单位**"。

任意层级元素,在使用`vw`单位的情况下,`1vw`都等于视图宽度的百分之一。

 vw单位换算

如果要将`px`换算成`vw`单位,只要确定视图的窗口大小(布局视口),如果我们将布局视口设置成分辨率大小。
比如对于iphone6/7 375*667的分辨率,那么px可以通过如下方式换算成`vw`:

```handlebars
1px = (1/375)*100 vw
```
此外,也可以通过`postcss`的相应插件,通过预处理`css`做一个自动的转换,`postcss-px-to-viewport`可以自动将`px`转化成`vw`。 `postcss-px-to-viewport`的默认参数为:

```handlebars
var defaults = {
  viewportWidth: 320,
  viewportHeight: 568, 
  unitPrecision: 5,
  viewportUnit: 'vw',
  selectorBlackList: [],
  minPixelValue: 1,
  mediaQuery: false
};
```
通过指定视窗的宽度和高度,以及换算精度,就能将`px`转化成`vw`。

vw/vh单位的兼容性

可以在[点击这里](https://caniuse.com/)查看各个版本的浏览器对vw单位的支持性。

可以发现,绝大多数的浏览器支持`vw`单位。

 vw/vh应用

首先,在项目中引入插件

```handlebars
npm install postcss-import postcss-loader postcss-px-to-viewport --save-dev
npm i postcss-px-to-viewport-opt
```
然后在根目录下面创建`postcss.config.js`

module.exports = {
    plugins: {
        "autoprefixer": {
            path: ['./src/*']
        },
        "postcss-import": {},
        "postcss-px-to-viewport-opt": {
            "viewportWidth": "1920", //视窗的宽度,对应的是我们设计稿的宽度
            "viewportHeight": "1080", // 视窗的高度
            "unitPrecision": 2, //指定`px`转换为视窗单位值的小数位数(很多时候无法整除)
            "viewportUnit": "vw", //指定需要转换成的视窗单位,建议使用vw
            "selectorBlackList": ['#nprogress'], //指定不转换为视窗单位的类
            "minPixelValue": 1, // 小于或等于`1px`不转换为视窗单位
            "mediaQuery": false, // 允许在媒体查询中转换`px`
            // "exclude": /(\/|\\)(node_modules)(\/|\\)/
        },
    }
};

然后重启项目,之后就可以在页面中写

```handlebars
.icon{
    color: $defaultColor;
    font-size: 26px;
}
```
实际编译结果如下:

2.P1.png

这样就实现了根据浏览器页面宽高字体大小自适应效果。

 vh 下载插件 postcss-viewport-units 时,使用使用伪类选择器遇到的问题

<!--在 .postcssrc.js 里配置-->
module.exports = {
  "plugins": {
    "postcss-import": {},
    "postcss-url": {},
    // to edit target browsers: use "browserslist" field in package.json
    // "autoprefixer": {},
      "postcss-aspect-ratio-mini": {},
      "postcss-write-svg": {
          utf8: false
      },
      "postcss-cssnext": {},
      "postcss-px-to-viewport": {
          // 视窗的宽度,对应的是我们设计稿的宽度,移动端一般是750,如果是pc端那就是类似1920这样的尺寸
          viewportWidth: 1920,
          viewportHeight: 1080,    // 视窗的高度,也可以不配置
          unitPrecision: 3,       // 指定`px`转换为视窗单位值的小数位数(很多时候无法整除)
          viewportUnit: 'vw',    // 指定需要转换成的视窗单位,建议使用vw
          // 过滤掉不转换为视窗单位的class类名,可以自定义,可以无限添加,建议定义一至两个通用的类名
          selectorBlackList: ['.ignore', '.hairlines'],  
          minPixelValue: 1,      // 小于或等于`1px`不转换为视窗单位,你也可以设置为你想要的值
          mediaQuery: false      // 允许在媒体查询中转换`px`
      },
      <!--postcss-viewport-units":{} 官方建议-->"
      <!--过滤掉::after ::before 的配置-->
      "postcss-viewport-units":{
          filterRule: rule => rule.selector.indexOf('::after') === -1 &&
          rule.selector.indexOf('::before') === -1 &&
          rule.selector.indexOf(':after') === -1 &&
          rule.selector.indexOf(':before') === -1
      },
      "cssnano": {
          preset: "default", // 设置成default将不会启用autoprefixer
          "postcss-zindex": false
      }
  }
}


使用 `vh` 后,会给每个普通`div`标签加上 `content` 属性,但是如果在伪类选择器上加上 `content` ,会显示出来,设置过滤函数会规避掉`::after` `::before`等。

使用 `vw/vh` 布局实现自适应优于其他方案,能够完美的解决调屏幕自适应问题。

【版权声明】本文为华为云社区用户原创内容,未经允许不得转载,如需转载请自行联系原作者进行授权。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。