一、px、em、rem 的概念及其之间的区别
在 css 中的单位长度使用中,比较常用的是 px、em、rem,三个单位的概念和区别是:px 是绝对值,em 与 rem 都是相对值
代码小案例:
<style>
:root{
/* 定义了一个根元素值 */
font-size: 1em;
}
.px{
font-size: 16px;
width: 200px;
height: 200px;
border: 1px solid red;
}
.em{
/* 字号被修改,新的值成为父级新值 */
font-size: 1.25em;
width: 15em;
height: 15em;
border: 1px solid blue;
}
.rem{
/* 字号取决于根元素的值 */
font-size: 1rem;
width: 20rem;
height: 20rem;
border: 1px solid springgreen;
}
</style>
</head>
<body>
<div class="container">
<div class="px">px绝对尺寸</div>
<div class="em">em相对尺寸</div>
<div class="rem">rem相对尺寸</div>
</div>
实例图
1. px:px 是固定像素单位,设置以后,在页面发生改变时,无法适应页面而去改变值的大小
2. em: em 相对于父元素,是相对父级元素字体大小的倍数
例如,父级 div 中字体设置了 12px, 在设置 2em 之后,该元素的字体大小就变成了 24px
3. rem: rem 相对于根元素(html),是相对 html 根元素字体大小的倍数
例如, html 默认的字体大小是 16px。所以,1rem 就相当于 16px。rem 的值最终取决于根元素默认值,其值是可以设置的
em 与 rem 的区分
em 相对于父元素,rem 相对于根元素(html)
总结:
二、vh,vw 写一个页面布局案例,欢迎大家指正
代码部分
<style>
* {
margin: 0;
padding: 0;
}
.header {
width: 100vw;
height: 10vh;
background-color: cornflowerblue;
line-height:10vh;
text-align:center;
position: relative;
font-size: 2rem;
justify-content: center;
display: flex;
}
.main {
float: left;
width: 100vw;
height: 70vh;
background: rgb(36, 221, 19);
line-height:70vh;
text-align:center;
font-size: 2rem;
justify-content: center;
display: flex;
}
.footer {
float: left;
width: 100vw;
height: 20vh;
background: rgb(221, 19, 194);
line-height:20vh;
text-align:center;
font-size: 2rem;
justify-content: center;
display: flex;
}
</style>
效果演示