http://www.w3chtml.com/css3/units/length/vh.html

https://www.html.cn/book/css/values/length/vh.htm

.em

在做手机端的时候经常会用到的做字体的尺寸单位

说白了 em就相当于“倍”,比如设置当前的div的字体大小为1.5em,则当前的div的字体大小为:当前div继承的字体大小*1.5

但是当div进行嵌套的时候,em始终是按照当前div继承的字体大小来缩放,参照后面的例子。

.rem

这里的r就是root的意思,意思是相对于根节点来进行缩放,当有嵌套关系的时候,嵌套关系的元素的字体大小始终按照根节点的字体大小进行缩放。

参照后面给的demo

.vh

vh就是当前屏幕可见高度的1%,也就是说

height:100vh == height:%;

但是有个好处是当元素没有内容时候,设置height:%该元素不会被撑开,

但是设置height:100vh,该元素会被撑开屏幕高度一致。

.vw

vw就是当前屏幕宽度的1%

补充一句,当设置width:%,被设置元素的宽度是按照父元素的宽度来设置,

但是100vw是相对于屏幕可见宽度来设置的,所以会出现50vw 比50%大的情况

<!DOCTYPE html>
<html lang="Zh-cn">
<head>
<meta charset="UTF-8">
<title>恭贺新春</title>
</head>
<style type="text/css" media="screen">
html{
font-size: 14px;
}
.em,
.em > .em-son,
.em > .em-son > .em-grandson {
font-size: .2em;
}
.rem,
.rem > .rem-son,
.rem > .rem-son > .rem-grandson {
font-size: .2rem;
}
.rem-box {
background: #d60b3b;
width:10rem;
height: 10rem;
color: #fff;
text-align: center;
line-height:5rem;
}
.vhvw-box {
background: #d60b3b;
width:50vw;
height: 50vh;
color: #fff;
text-align: center;
line-height:25vh;
}
</style>
<body>
<h1>em 继承父元素的字体大小,来变大或变小,多层嵌套字体变化</h1>
<div class="em">
字体大小 1.2 * (父元素body) = 16px
<div class="em-son">
字体大小 1.2 * (父元素em) = 20px
<div class="em-grandson">
字体大小 1.2 * (父元素em-son) = 24px
</div>
</div>
</div>
<br>
<h1>rem 继承根节点元素的字体大小,来变大或变小,多层嵌套字体不变化</h1>
<div class="rem">
字体大小 1.2 * (根节点html) = 16px
<div class="rem-son">
字体大小 1.2 * (根节点html) = 16px
<div class="rem-grandson">
字体大小 1.2 * (根节点html) = 16px
</div>
</div>
</div>
<br>
<h1>rem 也可作为固定长度单位设置宽高等</h1>
<div class="rem-box">
宽: * = 140px<br>
高: * = 140px
</div>
<br>
<h1>vh,vw 屏幕可见区域的高度,宽度的1%</h1>
<div class="vhvw-box">
宽:屏幕宽度的50%<br>
高:屏幕高度的50%
</div>
</body>
</html> <!DOCTYPE html>
<html lang="Zh-cn">
<head>
<meta charset="UTF-8">
<title>恭贺新春</title>
</head>
<style type="text/css" media="screen">
html{
font-size: 14px;
}
.em,
.em > .em-son,
.em > .em-son > .em-grandson {
font-size: .2em;
}
.rem,
.rem > .rem-son,
.rem > .rem-son > .rem-grandson {
font-size: .2rem;
}
.rem-box {
background: #d60b3b;
width:10rem;
height: 10rem;
color: #fff;
text-align: center;
line-height:5rem;
}
.vhvw-box {
background: #d60b3b;
width:50vw;
height: 50vh;
color: #fff;
text-align: center;
line-height:25vh;
}
</style>
<body>
<h1>em 继承父元素的字体大小,来变大或变小,多层嵌套字体变化</h1>
<div class="em">
字体大小 1.2 * (父元素body) = 16px
<div class="em-son">
字体大小 1.2 * (父元素em) = 20px
<div class="em-grandson">
字体大小 1.2 * (父元素em-son) = 24px
</div>
</div>
</div>
<br>
<h1>rem 继承根节点元素的字体大小,来变大或变小,多层嵌套字体不变化</h1>
<div class="rem">
字体大小 1.2 * (根节点html) = 16px
<div class="rem-son">
字体大小 1.2 * (根节点html) = 16px
<div class="rem-grandson">
字体大小 1.2 * (根节点html) = 16px
</div>
</div>
</div>
<br>
<h1>rem 也可作为固定长度单位设置宽高等</h1>
<div class="rem-box">
宽: * = 140px<br>
高: * = 140px
</div>
<br>
<h1>vh,vw 屏幕可见区域的高度,宽度的1%</h1>
<div class="vhvw-box">
宽:屏幕宽度的50%<br>
高:屏幕高度的50%
</div>
</body>
</html>

最新文章

  1. C++ 11 lambda
  2. Flex box弹性布局 及 响应式前端设计的优化
  3. web前端编写注意点
  4. 转:MVC单表多按钮提交
  5. Oracle 取随机数(转)
  6. 每周一道数据结构(四)A*算法&amp;博弈树α-β剪枝
  7. python scrapy 获取华为应用市场APP评论数据
  8. 将url转化成对象
  9. Linux Mint下编译Bochs
  10. 09.13日记(2014年9月13日00:18:26)英语,bootstrap,阮一峰,
  11. Windows编程坐标系统概念
  12. nopCommerce 3.9 大波浪系列 之 汉化-中文语言
  13. Python实战之IO多路复用select的详细简单练习
  14. Vue项目使用webstorm开发 保存浏览器不自动更新问题
  15. zookeeper权限问题
  16. nsswitch &amp; pam
  17. jmx - first demo
  18. Markdown 版本演进
  19. CF600E Lomsat gelral 【线段树合并】
  20. Ubuntu文本编辑(vi和nano)命令

热门文章

  1. Tableau Sheet中的操作
  2. 介绍知道的http返回的状态码
  3. GCD实战之多个网络请求的并发
  4. HDU - 6396 Swordsman (单调性+贪心)
  5. Ubuntu caffe 测试matlab接口
  6. gulp 自动化构建网站(版本号静态资源)
  7. 链接数据库模板 DataBaseLinkTool
  8. js/html 判断ie浏览器版本
  9. C# WCF发布服务的元数据的方式
  10. 12、label控件