博客列表 >CSS中em,rem,vw,vh的异同

CSS中em,rem,vw,vh的异同

Jason Pu?
Jason Pu?原创
2020年12月18日 11:00:46956浏览

如何识别em及rem这对双胞胎?

我们常用的px是固定像素,一旦设置了就无法因为适应页面而改变,em和rem相对于px更具有灵活性,因为他们是相对的长度单位,长度不是定死的,所以更适用于响应式布局。
在css中单位长度用的最多的是px、em、rem,因为em和rem都和字体大小相关,初学者常常混淆em,rem这对双胞胎,那么二者之间的区别是什么呢?我觉得一句话概括:em相对于父元素,rem相对于根元素(html),rem中的r意思是root(根源)。

举个粟子:

以下我们把根元素html的字体大小设置为20px,再写两个盒子:box1,box2,字体大小同样设置成16px,box1的宽高分别设置成10rem,box2的宽高分别设置成10em,我们会发现,相对box1,后者变小了

em/rem的运用场景:

想象一下,若你的css中有20处使用px来设置的属性。当你使用media query来进行响应式开发时,如果有两个尺寸断点,就要修改20*3=60处!如果使用em/rem,只需要修改1处

  1. <style>
  2. html {
  3. font-size: 16px;
  4. }
  5. @media screen and (min-width:600px){
  6. html{
  7. font-size: 20px;
  8. }
  9. }
  10. .title {
  11. font-size: 2rem;
  12. }
  13. .content{
  14. font: size 0.5rem;
  15. padding: 0.5em;
  16. text-indent: 2em;
  17. }
  18. </style>
  19. </head>
  20. <body>
  21. <div class="title">美媒记者:拜登一名顾问新冠病毒检测呈阳性</div>
  22. <div class="content">詹妮弗·雅各布斯(Jennifer Jacobs)在推特上宣布,拜登顾问塞德里克·里士满(Cedric Richmond)新冠病毒检测呈阳性。 此前,美国《国会山报》16日消息,美国一名记者新冠病毒检测呈阳性,本周二(15日)曾与当选总统拜登一同赴佐治亚州参加活动。拜登办公室方面发布声明称,出于高度谨慎,已指示一名通讯人员进行隔离。此外,过渡小组官员即刻对疫情保持追踪,并确定该名确诊记者并未与拜登有近距离接触。</div>
  23. </body>

em / rem /vh/ vw的区别与联系:

em,rem,vh,vw都是相对大小,不是绝对大小,em是相对于父元素的字体大小,rem是相对于根元素(html)的字体大小,vh是相对于视口高度的大小(view port height),vw是相对于视口的宽度大小(view port width),如果用户使用的是移动设备,可以根据横屏来调整当前页面,可以使用vmax,vmin

声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议