CSS 中 px,em和rem 的区别 学习笔记
2015-07-26 11:22
731 查看
简单讲,px是绝对单位,em和rem是相对单位。px大家都熟悉,这里主要讨论em和rem。
现在有以下一个段落:
当不给它设置字体大小时,使用默认大小,也就是16px大小,效果如下:
我们将span的大小改为2em,效果如下:
可以看到span的大小相对于p大了一倍,假设span里面还有一级标签:
现在我们知道p标签大小是
因为em是相对标签,所以不能设置成1em,而是相对于其父元素span的0.5em:
rem是指相对于html根元素的字体大小。
还是刚才的例子,我们想保证a标签字体大小和p标签一样,而p标签的大小正好是相对于html的 1倍,所以我们也可以将a标签的大小设置为
效果也是一样的。
现在有以下一个段落:
<p>当斧头来到树林的时候,好多树都说,至少<span>它的手柄</span>是自己人</p>
当不给它设置字体大小时,使用默认大小,也就是16px大小,效果如下:
em
em是指相对于父元素的大小,也就是说对于p和span而言,它的大小都是1em,这里的1em = 16px。我们将span的大小改为2em,效果如下:
span{ font-size: 2em; }
可以看到span的大小相对于p大了一倍,假设span里面还有一级标签:
<p>当斧头来到树林的时候,好多树都说,至少<span>它的<a>手柄</a></span>是自己人</p>
现在我们知道p标签大小是
1em,span的大小是
2em,如果想让a标签的大小和p标签一样,应该设置为多少?
因为em是相对标签,所以不能设置成1em,而是相对于其父元素span的0.5em:
a{ font-size: 0.5em; }
rem
使用em很好地将相对大小表现出来了,但是我们也发现在子元素里有时候想设置除了父元素以外的元素大小时,还要计算相对大小,rem就解决了这个问题。rem是指相对于html根元素的字体大小。
还是刚才的例子,我们想保证a标签字体大小和p标签一样,而p标签的大小正好是相对于html的 1倍,所以我们也可以将a标签的大小设置为
1rem:
a{ font-size: 1rem; }
效果也是一样的。
相关文章推荐
- Web布局连载——两栏固定布局(五)
- [div+css]晒晒最新制作专题推广页模板
- flash 系统字体显示问题
- 纯CSS制作的新闻网站中的文章列表
- 10条影响CSS渲染速度的写法与使用建议第1/3页
- BS项目中的CSS架构_仅加载自己需要的CSS
- 很不错的 CSS Hack 又学了一招
- 发一个css比较清爽的写法
- CSS expression控制图片自动缩放效果代码[兼容 IE,Firefox]
- css布局网页水平居中常用方法
- CSS经典技巧十则第1/2页
- css 兼容性问题this.style.cursor=''hand''
- IE6不能正常解析CSS文件问题的解决方法及原因分析
- 欲练CSS ,必先解决IE的一些细节分析
- CSS文字截取功能实现代码
- 支持IE6 IE7 Firefox 的纯CSS的下拉菜单
- 不同版本IE使用不同css(css条件注释语句用法)
- css类选择器的使用方法详解
- css文本框与按钮美化效果代码
- 解决ie动态修改link样式,import css不刷新的问题