本文主要是介绍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
表示相对于视图窗口高度,除了vw
和vh
外,还有vmin
和vmax
两个相关的单位。各个单位具体的含义如下:
这里我们发现视窗宽高都是100vw
/100vh
,那么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
转化成vw
。 postcss-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实现自定义布局的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!