块级元素与行内元素
块级元素与行内元素对比
1. 块级元素各自占据一行,垂直方向排列 ,旁边不能有其他元素,相当于它在元素框之前和之后生成了“分隔符”
行内元素不会独占一行,相邻的行内元素会排列在同一行里,知道一行排不下,才会换行
2. 块级元素可以设置宽与高,宽度不设置情况下默认为100%
行内设置宽高不起作用(可以设置line-height),其宽度随元素的内容而变化
3. 块级元素可以包含行内元素和块级元素。
行内元素不能包含块级元素。(即块级元素不能嵌套在行内元素中)
4. 块级元素可以设置padding, border, margin
行内元素的水平方向的padding-left,padding-right,margin-left,margin-right 都产生边距效果,但是竖直方向的padding-top,padding-bottom,margin-top,margin-bottom都不会产生边距效果。(水平方向有效,竖直方向无效)
行内元素border水平方向会撑开旁边的行内元素,垂直方向的border不占据空间,如下图 border: 20px solid rgba(122,122,22,.6);
所以行内元素也会产生块级元素盒子模型的“效果”,只不过垂直方向上不起作用。
5. 块级元素并不仅是指display:block的元素,而是符合块级元素特征的元素
行内元素也并不仅指display:inline的元素,而是符合行内元素特征的元素
6. img input等inlie-block元素也归为行内元素
7. inline的准确含义就是“行内”,而不是一般认为的“内联”
8. 可变元素,可变元素为根据上下文语境决定该元素为块元素或者内联元素,如button,与行内元素一起则表现为行内元素,与块级元素一起则表现为块级元素
9. 常见块级元素:p div ul ol li dl dt dd h1-h6 form table th tr td
常见行内元素:a b em i strong label img input
10. 通过display块级元素与行内元素之间可进行转换
11. 空元素指的是没有内容的元素,单标签元素属于空元素 如:<br/> <hr/>
<address> | 定义地址 |
<caption> | 定义表格标题 |
<dd> | 定义列表中定义条目 |
<div> | 定义文档中的分区或节 |
<dl> | 定义列表 |
<dt> | 定义列表中的项目 |
<fieldset> | 定义一个框架集 |
<form> | 创建 HTML 表单 |
<h1> | 定义最大的标题 |
<h2> | 定义副标题 |
<h3> | 定义标题 |
<h4> | 定义标题 |
<h5> | 定义标题 |
<h6> | 定义最小的标题 |
<hr> | 创建一条水平线 |
<legend> | 元素为 fieldset 元素定义标题 |
<li> | 标签定义列表项目 |
<noframes> | 为那些不支持框架的浏览器显示文本,于 frameset 元素内部 |
<noscript> | 定义在脚本未被执行时的替代内容 |
<ol> | 定义有序列表 |
<ul> | 定义无序列表 |
<p> | 标签定义段落 |
<pre> | 定义预格式化的文本 |
<table> | 标签定义 HTML 表格 |
<tbody> | 标签表格主体(正文) |
<td> | 表格中的标准单元格 |
<tfoot> | 定义表格的页脚(脚注或表注) |
<th> | 定义表头单元格 |
<thead> | 标签定义表格的表头 |
<tr> | 定义表格中的行 |
<a> | 标签可定义锚 |
<abbr> | 表示一个缩写形式 |
<acronym> | 定义只取首字母缩写 |
<b> | 字体加粗 |
<bdo> | 可覆盖默认的文本方向 |
<big> | 大号字体加粗 |
<br> | 换行 |
<cite> | 引用进行定义 |
<code> | 定义计算机代码文本 |
<dfn> | 定义一个定义项目 |
<em> | 定义为强调的内容 |
<i> | 斜体文本效果 |
<img> | 向网页中嵌入一幅图像 |
<input> | 输入框 |
<kbd> | 定义键盘文本 |
<label> | 标签为 input 元素定义标注(标记) |
<q> | 定义短的引用 |
<samp> | 定义样本文本 |
<select> | 创建单选或多选菜单 |
<small> | 呈现小号字体效果 |
<span> | 组合文档中的行内元素 |
<strong> | 语气更强的强调的内容 |
<sub> | 定义下标文本 |
<sup> | 定义上标文本 |
<textarea> | 多行的文本输入控件 |
<tt> | 打字机或者等宽的文本效果 |
<var> | 定义变量 |
<button> | 按钮 |
<del> | 定义文档中已被删除的文本 |
<iframe> | 创建包含另外一个文档的内联框架(即行内框架) |
<ins> | 标签定义已经被插入文档中的文本 |
<map> | 客户端图像映射(即热区) |
<object> | object对象 |
<script> | 客户端脚本 |