独占一行 html_HTML行内元素与块级元素有哪些及区别?

想起之前工作面试时,面试官问的一个问题:行内元素有哪些,和块级元素有什么区别?这是一道蛮基础的面试题,但是很多初学者平时只注重标签语义,忽视了标签行内和块级的特性, 因此对于上述问题很有可能答不上来或者答不全。

HTML常见的行内元素有:

、、 、 、、、

还有包括一些文本元素如:
等。

要是只回答和那就说不过去了吧。

HTML常见的块级元素有:

......

、 、
、、
、 、
等。

要是只回答

那就说不过去了吧。

那它们之间的区别是什么呢?

·块级元素

1.总是从新的一行开始,即各个块级元素独占一行,默认垂直向下排列;

2.高度、宽度、margin及padding都是可控的,设置有效,有边距效果;

3.宽度没有设置时,默认为100%;

4.块级元素中可以包含块级元素和行内元素。

·行内元素

1.和其他元素都在一行,即行内元素和其他行内元素都会在一条水平线上排列;

2.高度、宽度是不可控的,设置无效,由内容决定。

设置margin左右有效,有边距效果;

设置margin上下会撑大空间但是不会产生边距效果(即盒模型margin-top/bottom有值,但页面上没有边距效果)。

设置padding左右有效,设置padding上下会撑大空间但是不会产生边距效果(同上)。

padding效果如下展示:

         
块级元素
行内元素 行内元素
块级元素
de4e33070194ea6f5652d2fe7572a513.png

3.根据标签语义化的理念,行内元素最好只包含行内元素,不包含块级元素。

转换

当然块级元素与行内元素之间的特性是可以相互转换的。HTML可以将元素分为行内元素、块状元素和行内块状元素三种。

使用display属性能够将三者任意转换:

(1)display:inline;转换为行内元素;

  (2)display:block;转换为块状元素;

  (3)display:inline-block;转换为行内块状元素。

行内块状元素综合了行内元素和块状元素的特性:

(1)不自动换行,与其他行内元素都会在一条水平线上排列;

(2)高度、宽度、margin及padding都是可控的,设置有效,有边距效果;

(3)默认排列方式为从左到右。

121cc040535ad06be326d3913ee86e37.png
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值