px、em、rem的区别

发布时间:2023年12月26日

三者区别:

  1. px是像素单位,可以用来设置屏幕宽高 ,一旦设置了就无法因为适应页面大小而改变。
  2. em和rem相对于px更具有灵活性,他们是相对长度单位,意思是长度不是定死了的,更适用于响应式布局。
  3. em是相对于其父元素来设置字体大小的,一般都是以的“font-size”为基准。这样就会存在一个问题,进行任何元素设置,都有可能需要知道他父元素的大小。而rem是相对于根元素,这样就意味着,我们只需要在根元素确定一个参考值。
    总之em相对于父元素,rem相对于根元素,也就是相对于html标签。

em实例:

  • 子元素字体大小的em是相对于父元素字体大小
  • 元素的width/height/padding/margin用em的话是相对于该元素的font-size
  • 任何浏览器默认字体大小都是16px,所有未经调整的浏览器都符合1em=16px

em举例:

比如父元素font-size:12px;
自身元素如果写成:font-size:2em;则自身元素用px表示就是24px(相对父元素字体大小);
但是自身元素设置:width:2 em,那么自身元素用px表示就是48px(相对自身字体大小);

<!DOCTYPE html>
<html lang="en">
 
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        div {
            font-size: 40px;
            width: 7.5em;  /* 300px */
            height: 7.5em;
            background-color: gray;
        }
        
        p {
            font-size: 0.5em; /* 20px */
            width: 7.5em;     /* 150px */
            height: 7.5em;
            color: blue;
            background-color: tan;
            margin: 0;
        }
        
        span {
            font-size: 0.5em;
            width: 7em;
            height: 6em;
            background-color: #fff;
            display: block;
            color: red;
        }
    </style>
</head>
 
<body>
    <div>
        父元素div
        <p>
            子元素p
            <span>孙元素span</span>
        </p>
    </div>
</body>
 
</html>

rem实例:

rem是全部的长度都相对于根元素(元素)。通常做法是给html元素设置一个字体大小,然后其他元素的长度单位就为rem。

rem举例:

比如根元素(html)设置font-size=12px; 非根元素设置width:2rem;则换成px表示就是24px;
如果根元素设置成font-size=1rem;则根元素换成px就是相对于初始字体大小,一般是12px,换算规则1rem不能小于12px

通过媒体查询分别设置每个屏幕的根font-size
css直接除以2再除以100即可换算成rem

优:有一定适用性,换算也较为简单
劣:有兼容性的坑,对不同手机适配不是非常精确;需要设置多个媒体查询来适应不同手机,当某款手机尺寸不在设置范围内,会导致无法适配

<!DOCTYPE html>
<html lang="en">
 
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        html {
            font-size: 10px;
        }
        
        div {
            font-size: 4rem;  /* 40px */
            width: 20rem;     /* 200px */
            height: 20rem;
            color: black;
            background-color: darkcyan;
        }
        
        p {
            font-size: 2rem;  /* 20px */
            width: 10rem;
            height: 10rem;
            color: blue;
            background-color: purple;
            margin: 0;
        }
        
        span {
            font-size: 1.5rem;
            width: 7rem;
            height: 6rem;
            display: block;
            color: red;
            background-color: sandybrown;
        }
    </style>
</head>
 
<body>
    <div>
        父元素div
        <p>
            子元素p
            <span>孙元素span</span>
        </p>
    </div>
</body>
 
</html>

总结:

  1. rem 和 em 单位是由浏览器基于你的设计中的字体大小计算得到的像素值。
  2. em 单位基于使用他们的元素的字体大小。
  3. rem 单位基于 html 元素的字体大小。
  4. em 单位可能受任何继承的父元素字体大小影响。
  5. rem 单位可以从浏览器字体设置中继承字体大小。
  6. 使用 em 单位应根据组件的字体大小而不是根元素的字体大小。
  7. 在不需要使用em单位,并且需要根据浏览器的字体大小设置缩放的情况下使用rem。
  8. 使用rem单位,除非你确定你需要 em 单位,包括对字体大小。
  9. 媒体查询中使用 rem 单位。
  10. 不要在多列布局中使用 em 或 rem -改用 %。
  11. 不要使用 em 或 rem,如果缩放会不可避免地导致要打破布局元素。

欢迎补充~~~

文章来源:https://blog.csdn.net/Quentin0823/article/details/135218183
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。