px、em、rem的区别
2023-12-26 12:29:13
三者区别:
- px是像素单位,可以用来设置屏幕宽高 ,一旦设置了就无法因为适应页面大小而改变。
- em和rem相对于px更具有灵活性,他们是相对长度单位,意思是长度不是定死了的,更适用于响应式布局。
- 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>
总结:
- rem 和 em 单位是由浏览器基于你的设计中的字体大小计算得到的像素值。
- em 单位基于使用他们的元素的字体大小。
- rem 单位基于 html 元素的字体大小。
- em 单位可能受任何继承的父元素字体大小影响。
- rem 单位可以从浏览器字体设置中继承字体大小。
- 使用 em 单位应根据组件的字体大小而不是根元素的字体大小。
- 在不需要使用em单位,并且需要根据浏览器的字体大小设置缩放的情况下使用rem。
- 使用rem单位,除非你确定你需要 em 单位,包括对字体大小。
- 媒体查询中使用 rem 单位。
- 不要在多列布局中使用 em 或 rem -改用 %。
- 不要使用 em 或 rem,如果缩放会不可避免地导致要打破布局元素。
欢迎补充~~~
文章来源:https://blog.csdn.net/Quentin0823/article/details/135218183
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!