CSS2 从入门到精通 (3)

外边距指的是当前盒子与其他盒子之间的距离,他不会影响可见框的大小,而是会影响到盒子的位置。由于页面中的元素都是靠左靠上摆放的,所以注意当我们设置上和左外边距时,会导致盒子自身的位置发生改变。_
margin还可以设置为auto,auto一般只设置给水平方向的margin如果只指定,左外边距或右外边距的margin为auto则会将外边距设置为最大值垂直方向外边距如果设置为auto,则外边距默认就是0如果将left和right同时设置为auto,则会将两侧的外边距设置为相同的值,就可以使元素自动在父元素中居中,所以我们经常将左右外边距设置为auto。

1. 垂直外边距重叠

垂直外边距的重叠在网页中相邻垂直方向的外边距会发生外边距的重叠所谓的外边距重叠指兄弟元素之间的相邻外边距会取最大值而不是取和.
如果父子元素的
垂直外边 距相邻 **了,则子元素的外边距会设置给父元素.

2. 如何解决外边距重叠

在两个元素之家加其他元素

添加 border

添加 padding

注意:内联元素是不支持垂直方向的外边距的,其他的都和块级元素相同。

7. 元素展示方式 1. display

将一个内联元素变成块元素, 通过display样式可以修改元素的类型
可选值:

inline:可以将一个元素作为内联元素显示

block: 可以将一个元素设置块元素显示

inline-block:将一个元素转换为行内块元素可以使一个元素既有行内元素的特点又有块元素的特点既可以设置宽高,又不会独占一行

none: 不显示元素,并且元素不会在页面中继续占有位置使用该方式隐藏的元素,不会在页面中显示,并且不再占据页面的位置

2. visibility 可以用来设置元素的隐藏和显示的状态
可选值:

visible 默认值,元素默认会在页面显示

hidden 元素会隐藏不显示,使用 visibility:hidden;隐藏的元素虽然不会在页面中显示,但是它的位置会依然保持

3. overflow

子元素默认是存在于父元素的内容区中,
理论上讲子元素的最大可以等于父元素内容区大小
如果子元素的大小超过了父元素的内容区,则超过的大小会在父元素以外的位置显
超出父元素的内容,我们称为溢出的内容
父元素默认是将溢出内容,在父元素外边显示,
通过overflow可以设置父元素如何处理溢出内容:
可选值:
- visible,默认值,不会对溢出内容做处理,元素会显示
- hidden, 溢出的内容,会被修剪,不会显示
- scroll, 会为父元素添加滚动条,通过拖动滚动条该属性不论内容是否溢出,都会添加水平
- auto,会根据需求自动添加滚动条,需要水平就添加水平需要垂直就添加垂直都不需要就都不加

8. 文档流

文档流文档流处在网页的最底层,它表示的是一个页面中的位置,我们所创建的元素默认都处在文档流中
元素在文档流中的特点

1.块元素

1.块元素在文档流中会独占一行,块元素会自上向下排列。
2.块元素在文档流中默认宽度是父元素的100%
3.块元素在文档流中的高度默认被内容撑开

2.内联元素

1.内联元素在文档流中只占自身的大小,会默认从左向右排列,如果一行中不足以容纳所有的内联元素,则换到下一行,继续自左向右。
2.在文档流中,内联元素的宽度和高度默认都被内容撑开

9. 浮动

块元素在文档流中默认垂直排列, 如果希望块元素在页面中水平排列,可以使块元素脱离文档流使用float来使元素浮动,从而脱离文档流
可选值:

none,默认值,元素默认在文档流中排列

left,元素会立即脱离文档流,向页面的左侧浮动

right,元素会立即脱离文档流,向页面的右侧浮动

1. 浮动的规则

当为一个元素设置浮动以后(float属性是一个非none的值), 元素会立即脱离文档流,元素脱离文档流以后,它下边的元素会立即向上移动 元素浮动以后,会尽量向页面的左上或右上漂浮, 直到遇到父元素的边框或者其他的浮动元素
如果浮动元素上边是一个没有浮动的块元素,则浮动元素不会超过块元素。
浮动的元素不会超过他上边的兄弟元素,最多最多一边齐。
浮动的元素不会盖住文字,文字会自动环绕在浮动元素的周围
在文档流中,子元素的宽度默认占父元素的全部当元素设置浮动以后,会完全脱离文档流.块元素脱离文档流以后,高度和宽度都被内容撑开
开启span的浮动内联元素脱离文档流以后会变成块元素

2. 浮动后高度塌陷

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wsxdwz.html