html新建盒子,html 盒子模型

盒子

CSS处理网页时,它认为每个元素都包含在一 个不可见的盒子里。

为什么要想象成盒子呢?因为如果把所有的元 素都想象成盒子,那么我们对网页的布局就相 当于是摆放盒子。

我们只需要将相应的盒子摆放到网页中相应的 位置即可完成网页的布局。

盒子模型

一个盒子我们会分成几个部分:

内容区(content)

内边距(padding)

边框(border)

外边距(margin)

3cc4675130b1

捕获.PNG

内容区

内容区指的是盒子中放置内容的区域,也就是元素 中的文本内容,子元素都是存在于内容区中的。

如果没有为元素设置内边距和边框,则内容区大小 默认和盒子大小是一致的。

通过width和height两个属性可以设置内容区的大 小。

width和height属性只适用于块元素。

内边距

顾名思义,内边距指的就是元素内容区与边框以内 的空间。

默认情况下width和height不包含padding的大小。

使用padding属性来设置元素的内边距。

例如:

padding:10px 20px 30px 40px

这样会设置元素的上、右、下、左四个方向的内边距。

padding:10px 20px 30px;

分别指定上、左右、下四个方向的内边距

padding:10px 20px;

分别指定上下、左右四个方向的内边距

padding:10px;

同时指定上左右下四个方向的内边距

同时在css中还提供了padding-top、padding-left、padding-right、padding-bottom分别用来指定四个方向的内边距。

边框

可以在元素周围创建边框,边框是元素可见框的最外部。

可以使用border属性来设置盒子的边框:

border:1px red solid;

上边的样式分别指定了边框的宽度、颜色和样式。

也可以使用border-top/left/right/bottom分别指定上右下左 四个方向的边框。

和padding一样,默认width和height并包括边框的宽度

边框的样式

边框可以设置多种样式:

none(没有边框)

dotted(点线)

dashed(虚线)

solid(实线)

double(双线)

groove(槽线)

ridge(脊线)

inset(凹边)

outset(凸边)

外边距

外边距是元素边框与周围元素相距的空间。

使用margin属性可以设置外边距。

用法和padding类似,同样也提供了四个方向的 margin-top/right/bottom/left。

当将左右外边距设置为auto时,浏览器会将左右外 边距设置为相等,所以这行代码margin:0auto可 以使元素居中。

display

我们不能为行内元素设置width、height、 margin-top和margin-bottom。

我们可以通过修改display来修改元素的性 质。

可选值:

block:设置元素为块元素

inline:设置元素为行内元素

inline-block:设置元素为行内块元素

none:隐藏元素(元素将在页面中完全消失)

visibility

visibility属性主要用于元素是否可见。

和display不同,使用visibility隐藏一个元 素,隐藏后其在文档中所占的位置会依然 保持,不会被其他元素覆盖。

可选值:

visible:可见的

hidden:隐藏的

overflow

当相关标签里面的内容超出了样式的宽度 和高度是,就会发生一些奇怪的事情,浏 览器会让内容溢出盒子。

可以通过overflow来控制内容溢出的情况。

可选值:

visible:默认值

scroll:添加滚动条

auto:根据需要添加滚动条

hidden:隐藏超出盒子的内容

浮动

所谓浮动指的是使元素脱离原来的文本流,在父元素中浮动起来。

浮动使用float属性。

可选值:

none:不浮动

left:向左浮动

right:向右浮动

块级元素和行内元素都可以浮动,当一个行内元素浮动以后将会自动变为一 个块级元素。

当一个块级元素浮动以后,宽度会默认被内容撑开,所以当漂浮一个块级元 素时我们都会为其指定一个宽度。

当一个元素浮动以后,其下方的元素会上移。元素中的内容将会围绕 在元素的周围。

浮动会使元素完全脱离文本流,也就是不再在文档中在占用位置。

元素设置浮动以后,会一直向上漂浮直到遇到父元素的边界或者其他 浮动元素。

元素浮动以后即完全脱离文档流,这时不会再影响父元素的高度。也 就是浮动元素不会撑开父元素。

浮动元素默认会变为块元素,即使设置display:inline以后其依然是个 块元素。

清除浮动

clear属性可以用于清除元素周围的浮动对元素的影响。

也就是元素不会因为上方出现了浮动元素而改变位置。

可选值:

left:忽略左侧浮动

right:忽略右侧浮动

both:忽略全部浮动

none:不忽略浮动,默认值

文档流

文档流

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

元素在文档流中的特点

块元素

1.块元素在文档流中会独占一行,块元素会自上向下排列

2.块元素在文档流中默认宽度是父元素的100%

3.块元素在文档流中的高度默认被内容撑开

内联元素

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

2.在文档流中,内联元素的宽度和高度默认都被内容撑开

文字绕图

浮动的元素不会盖住文字,文字会自动环绕在浮动元素的周围,所以我们可以通过浮动来设置文字环绕图片的效果

高度塌陷

根据W3C的标准,在页面中元素都一个隐含的属性叫做Block Formatting Context(块的格式化环境)简称BFC,该属性可以设置打开或者关闭,默认是关闭的

当开启元素的BFC以后,元素将会具有如下的特性:

1.父元素的垂直外边距不会和子元素重叠

2.开启BFC的元素不会被浮动元素所覆盖

3.开启BFC的元素可以包含浮动的子元素

如何开启元素的BFC

1.设置元素浮动

- 使用这种方式开启,虽然可以撑开父元素,但是会导致父元素的宽度丢失,而且使用这种方式也会导致下边的元素上移,不能解决问题

2.设置元素绝对定位

3.设置元素为inline-block

- 可以解决问题,但是会导致宽度丢失,不推荐使用这种方式

4.将元素的overflow设置为一个非visible的值

推荐方式:将overflow设置为hidden是副作用最小的开启BFC的方式

但是在IE6及以下的浏览器中并不支持BFC,所以使用这种方式不能兼容IE6

在IE6中虽然没有BFC,但是具有另一个隐含的属性叫做hasLayout,该属性的作用和BFC类似,所在IE6浏览器可以通过开hasLayout来解决该问题

开启方式很多,我们直接使用一种副作用最小的:

直接将元素的zoom设置为1即可

zoom表示放大的意思,后边跟着一个数值,写几就将元素放大几倍

zoom:1表示不放大元素,但是通过该样式可以开启hasLayout

zoom这个样式,只在IE中支持,其他浏览器都不支持

解决高度塌陷

解决高度塌陷

.box1{

border: 1px solid red;

}

.box2{

width: 100px;

height: 100px;

background-color: blue;

float: left;

}

/*通过after伪类,选中box1的后边*/

/*

可以通过after伪类向元素的最后添加一个空白的块元素,然后对其清除浮动,

这样做和添加一个div的原理一样,可以达到一个相同的效果,

而且不会在页面中添加多余的div,这是我们最推荐使用的方式,几乎没有副作用

*/

.clearfix:after{

/*添加一个内容*/

content: "";

/*转换为一个块元素*/

display: block;

/*清除两侧的浮动*/

clear: both;

}

/*在IE6中不支持after伪类,所以在IE6中还需要使用hasLayout来处理*/

.clearfix{

zoom: 1;

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值