美文网首页实用前端程序员Web前端之路
你不一定知道的CSS的那些小事

你不一定知道的CSS的那些小事

作者: 该帐号已被查封_才怪 | 来源:发表于2017-03-31 17:42 被阅读176次
1、元素的margin的top、bottom及padding的top、bottom使用百分比作为单位时,其是相对父元素的宽度width的而不是我们想象的高度height;

举个例子:

Paste_Image.png

其实出现这种现象,我们可以巧用margin/padding的百分比值实现高度自适应(多用于占位,避免闪烁)

当然该元素高度上的百分比是相对其父元素高度的百分比的,min-height及max-height也适用这条规律。

Paste_Image.png
2、含有定位属性的元素,其top、bottom单位为百分比时,该百分比是相对于父元素的高度的。同理,left、right则是相对于父元素的宽度的。
Paste_Image.png

这一点,我昨天在查资料写这篇文章---最全面的元素水平垂直居中方法汇总的时候就发现有个大牛也理解错了----CSS布局奇淫技巧之--各种居中 里面的第八点。

3、边框宽度不允许使用百分比值

这点就不解释了。

4、width:100%

当父容器里有 绝对定位 的子元素时,子元素设置width:100%实际上指的是相对于父容器的padding+content的宽度。当子元素是非绝对定位的元素时width:100%才是指子元素的 content ,其等于父元素的 content宽度。

Paste_Image.png

将上面子元素的position改成了relative后,其宽度就变成了parent宽度。

Paste_Image.png

https://codepen.io/anon/pen/RxWQNK

5、line-height

你知道line-height:150%和line-height:1.5的区别吗?知道了就可以跳过此处,不知道继续看下面:
举个例子:

有单位的例子 无单位的例子

上面可以看到line-height有单位时,子元素是继承父元素的line-height的,无单位时,其line-height等于无单位的数值乘以子元素本身的字体大小。显然为了不出现意外,还是建议首选无单位的。

6、ex 和 ch 单位

ex:取当前作用效果的字体的x的高度,在无法确定x高度的情况下以0.5em计算;
ch:以节点所使用字体中的“0”字符为基准,找不到时为0.5em;

Paste_Image.png

ex 和 ch 单位,类似于 em 和 rem, 依赖于当前的字体和字体大小。 但是,不同的是,这两货是基于字体的度量单位,依赖于设定的字体。
ch 单位通常被定义为数字0的宽度。你可以在Eric Meyers的博客里找到关于它的一些有意思的讨论,例如将一个等宽字体的字母”N”的宽度设置为40ch,那么在另一种类型的字体里它却可以包含40个字母。这个单位的传统用途主要是盲文的排版,但是除此之外,肯定还有可以应用他的地方。
ex 定义为当前字体的小写x字母的高度或者 1/2 的 1em。 很多时候,它是字体的中间标志。

Paste_Image.png

x-height; the height of the lower case x
这些单位有很多用途,大部分用于版式的微调。比方说,sup 元素(上角文字标),可以通过position:relative;bottom: 1ex;实现 。类似的方法,你可以实现一个下角文字标。浏览器默认的方式是利用
上标和下标特定垂直对齐规则,但是如果你想更细粒度更精确得控制,你可以像下面这样做:
Css代码

sup {  
    position: relative;  
    bottom: 1ex;  
}  
sub {  
    position: relative;  
    bottom: -1ex;  
} 
7、使用calc 时运算符之间要有空格 ,否则可能无效
 width: calc(100% - 20px);  //注:减号前后要有空格,否则很可能不生效!!
8、当body里面有含有margin的子元素处于body正常文档流时,

那么body的大小不会包含处于最上部的元素的margin-top(会包含margin-left及margin-right)及最下部的元素的margin-bottom(会包含margin-left及margin-right),但是html却都包含(也会包含margin-left及margin-right);
例如:https://codepen.io/anon/pen/baVaya 或者https://codepen.io/anon/pen/VyvyJa

扩展阅读:

1、最全面的元素水平垂直居中方法汇总
2、12个很少被人知道的CSS事实
3、Vertical Percentages in CSS

**本文版权归本人即简书笔名:该账户已被查封 所有,如需转载请注明出处。谢谢! *

相关文章

  • 你不一定知道的CSS的那些小事

    1、元素的margin的top、bottom及padding的top、bottom使用百分比作为单位时,其是相对父...

  • CSS定位的那些小事儿

    定位作为页面布局的一部分,对面设计页面至关重要.写了那么多的CSS却至今写不好定位?不要慌,今天我们就来总结一下C...

  • 那些小事

    我猜,你的酒窝会被那些小事填满 我想,你的眉头会被那些小事挤皱 还好,那些小事都那么可爱 给了我们那么多值得回忆的...

  • (六)Android开发进阶(转)

    Android View 简介 View的简介 那些你应该知道却不一定知道的——View坐标分析汇总 Androi...

  • 那些你不知道的Android小事儿

    科技改变生活,作为现代化科技的代表作之一,手机,已经成为人们生活中不可或缺的一部分,而作为手机操作系统的翘楚代表,...

  • Android View相关文章精选

    View 简介 View的简介 坐标相关 那些你应该知道却不一定知道的——View坐标分析汇总Android应用坐...

  • 那些温暖你的小事

    有些人非常善良,他们乐于助人,雪中送炭,救别人于危难之中,世界上正是有这样的人存在才美好,可惜我已经不是这样的人了...

  • 你不一定知道的css知识——包含块

    包含块(containing block) 这里是css2.1规范10.1章节对包含块的解释 包含块的定义(我不讨...

  • 爱情故事

    我非常清晰对自己说,如果你想写爱情,那就写。你有你的路,那些你知道的,没人知道,或不一定知道。就放胆过去吧,成功等...

  • Android这四个你不可不知的知识点,你都了解多少?

    那些你不一定知道的Android知识N系列... Android的四大组件 Activity (活动) Servi...

网友评论

    本文标题:你不一定知道的CSS的那些小事

    本文链接:https://www.haomeiwen.com/subject/zlevottx.html