学习链接https://www.bilibili.com/video/av75501761?p=2
父元素
宽度最大填充父元素,高度正好容纳子元素。
如果子元素左浮动,则宽度仍在容纳子元素的基础上最大填充父元素,高度正好容纳子元素
如果子元素右浮动,则宽度正好容纳子元素,高度正好容纳子元素
这是因为子元素默认就是独占一行,向左对齐的。
可以通过对父元素overflow:hidden,来实现自身的最大填充
div块状属性是有独占一行的特性,默认是纵向排列,一旦设置float:left,则会以行来横向浮动排列。
1.将元素排除在普通流之外
2.元素将不在页面中占据空间
3.将浮动元素放置在包含框的左边或者右边
4.浮动元素依旧位于包含框之内
子元素的浮动是基于父元素框体的
浮动可以通过CSS clear清除
none,inline,block,inline-block,table-cell,flex
每个元素都有一个display属性,如div的display属性为block(块元素),而span元素的display属性为inline(行内元素)
行内元素(inline):
1.没有宽高属性,不会独占一行
如span,设置宽高均无用
2.行内元素一旦设置了float定位或者设置display=block(设置为块状元素),宽高属性生效
inline-block:既有宽高属性,并且不会独占一行,但是功能多可用浮动实现,使用较少。
display:none;隐藏元素,不保留物理空间
visibility:hidden;隐藏元素,保留物理空间
值 | 描述 |
---|---|
absolute | 生成绝对定位的元素,相对于 static 定位以外的第一个父元素进行定位。元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。 |
fixed | 生成绝对定位的元素,相对于浏览器窗口进行定位。元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。 |
relative | 生成相对定位的元素,相对于其正常位置进行定位。因此,"left:20" 会向元素的 LEFT 位置添加 20 像素。 |
static | 默认值。没有定位,元素出现在正常的流中(忽略 top, bottom, left, right 或者 z-index 声明)。 |
inherit | 规定应该从父元素继承 position 属性的值。 |
z-index:可以手动调节覆盖的参数,z-index越高越能覆盖其他元素
盒模型主要定义4个区域:内容(content),内边距(padding),边框(border),外边距(margin)
外边距(margin)的合并,以外边距大的为主
行内元素不占上下外边距,左右外边距也不会合并
浮动元素的外边距不会合并
允许指定负的外边距
border边框,默认3px,参数为长度,样式,颜色,会扩大区域
padding会扩大元素边框占用区域
W3C
IE,IE盒子模型的宽和高包括了border和padding
box-sizing允许指定标准盒模型和怪异盒模型
content-box(标准)
border-box(怪异)
javascript
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。