Vue进阶(幺陆捌):前端用户体验提升(三)应用vw/vh实现自定义布局

本文主要是介绍Vue进阶(幺陆捌):前端用户体验提升(三)应用vw/vh实现自定义布局,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 一、了解vw/vh
      • 1.1 vw/vh 定义
      • 1.2 vw 单位换算
      • 1.3 vw/vh 单位兼容性
      • 1.4 vw/vh 应用
      • 1.5 vh 下载插件 postcss-viewport-units 时,使用伪类选择器遇到的问题
    • 二、与 % 区别
    • 三、兼容性
    • 四、拓展阅读


一、了解vw/vh

vw/vh单位可以根据电脑浏览器自适应。

  • vw —— 视口宽度的 1/100;
  • vh —— 视口高度的 1/100

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

1.1 vw/vh 定义

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

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

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

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

1.2 vw 单位换算

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

1px = 1/375*100 vw

此外,也可以通过postcss的相应插件,通过预处理css做一个自动的转换,postcss-px-to-viewport可以自动将px转化成vwpostcss-px-to-viewport的默认参数为:

var defaults = {viewportWidth: 320,viewportHeight: 568, unitPrecision: 5,viewportUnit: 'vw',selectorBlackList: [],minPixelValue: 1,mediaQuery: false
};

通过指定视窗的宽度和高度,以及换算精度,就能将px转化成vw

1.3 vw/vh 单位兼容性

可以在点击这里查看各个版本的浏览器对vw单位的支持性。

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

1.4 vw/vh 应用

首先,在项目中引入插件

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)(\/|\\)/},}
};

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

.icon{color: $defaultColor;font-size: 26px;
}

实际编译结果如下:
在这里插入图片描述

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

1.5 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 布局实现自适应优于其他方案,能够完美的解决调屏幕自适应问题。

二、与 % 区别

% 是相对于父元素大小设定的比率,vw 由视窗大小决定。

其实这些视窗单位与%使用基本类似,优势在于能够直接获取高度,而用%在没有设置body高度的情况下,是无法正确获得可视区域的高度的,所以这是挺不错的优势。

三、兼容性

移动设备上兼容没问题。

在这里插入图片描述

四、拓展阅读

  • 《网站开发进阶(六十六)CSS3 - 新单位vmin/vmax与旧单位ex/ch使用详解》

  • caniuse官网

  • 《网站开发进阶(六十七)浅谈css中hsl()和hsla()设置颜色值的方法与应用》

  • 《Vue进阶(幺柒陆):CSS预编译语言Sass、Scss、Less和Stylus》

  • 《Vue进阶(幺柒柒):Vue应用Sass、Scss、Less和Stylus》

  • 《Vue进阶(幺柒捌):延伸阅读Sass、Scss、Less与Stylus编程特性》

  • 《网站开发进阶(六十六)CSS3 - 新单位vmin/vmax与旧单位ex/ch使用详解》

  • 《网站开发进阶(六十四)CSS 属性选择器》

  • 《网站开发进阶(六十五)css中 :not() 伪类选择器用法》

  • 《网站开发进阶(六十二)最强大的 CSS 布局——Grid 布局》

  • 《Vue进阶(幺柒零):前端用户体验提升(四)应用rem/em实现字体自适应》

  • 《Vue进阶(幺柒幺):前端用户体验提升(五)Flex实现弹性布局》

  • 《网站开发进阶(六十三)详解CSS3中的calc()》

这篇关于Vue进阶(幺陆捌):前端用户体验提升(三)应用vw/vh实现自定义布局的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/715402

相关文章

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解

PostgreSQL中MVCC 机制的实现

《PostgreSQL中MVCC机制的实现》本文主要介绍了PostgreSQL中MVCC机制的实现,通过多版本数据存储、快照隔离和事务ID管理实现高并发读写,具有一定的参考价值,感兴趣的可以了解一下... 目录一 MVCC 基本原理python1.1 MVCC 核心概念1.2 与传统锁机制对比二 Postg

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

C++中零拷贝的多种实现方式

《C++中零拷贝的多种实现方式》本文主要介绍了C++中零拷贝的实现示例,旨在在减少数据在内存中的不必要复制,从而提高程序性能、降低内存使用并减少CPU消耗,零拷贝技术通过多种方式实现,下面就来了解一下... 目录一、C++中零拷贝技术的核心概念二、std::string_view 简介三、std::stri

C++高效内存池实现减少动态分配开销的解决方案

《C++高效内存池实现减少动态分配开销的解决方案》C++动态内存分配存在系统调用开销、碎片化和锁竞争等性能问题,内存池通过预分配、分块管理和缓存复用解决这些问题,下面就来了解一下... 目录一、C++内存分配的性能挑战二、内存池技术的核心原理三、主流内存池实现:TCMalloc与Jemalloc1. TCM

OpenCV实现实时颜色检测的示例

《OpenCV实现实时颜色检测的示例》本文主要介绍了OpenCV实现实时颜色检测的示例,通过HSV色彩空间转换和色调范围判断实现红黄绿蓝颜色检测,包含视频捕捉、区域标记、颜色分析等功能,具有一定的参考... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间

全面解析HTML5中Checkbox标签

《全面解析HTML5中Checkbox标签》Checkbox是HTML5中非常重要的表单元素之一,通过合理使用其属性和样式自定义方法,可以为用户提供丰富多样的交互体验,这篇文章给大家介绍HTML5中C... 在html5中,Checkbox(复选框)是一种常用的表单元素,允许用户在一组选项中选择多个项目。本

HTML5 搜索框Search Box详解

《HTML5搜索框SearchBox详解》HTML5的搜索框是一个强大的工具,能够有效提升用户体验,通过结合自动补全功能和适当的样式,可以创建出既美观又实用的搜索界面,这篇文章给大家介绍HTML5... html5 搜索框(Search Box)详解搜索框是一个用于输入查询内容的控件,通常用于网站或应用程

Python实现精准提取 PDF中的文本,表格与图片

《Python实现精准提取PDF中的文本,表格与图片》在实际的系统开发中,处理PDF文件不仅限于读取整页文本,还有提取文档中的表格数据,图片或特定区域的内容,下面我们来看看如何使用Python实... 目录安装 python 库提取 PDF 文本内容:获取整页文本与指定区域内容获取页面上的所有文本内容获取

基于Python实现一个Windows Tree命令工具

《基于Python实现一个WindowsTree命令工具》今天想要在Windows平台的CMD命令终端窗口中使用像Linux下的tree命令,打印一下目录结构层级树,然而还真有tree命令,但是发现... 目录引言实现代码使用说明可用选项示例用法功能特点添加到环境变量方法一:创建批处理文件并添加到PATH1