1.关于行内元素和块级元素的说明
块级元素会自动占据一定矩形空间,可以通过设置高度、宽度、内外边距等属性,来调整这个矩形的样子;与之相反,行内元素,则没有自己的独立空间,它是依附于其他块级元素存在的,因此,对行内元素设置高度、宽度、内外边距等属性,都是无效的。(置换元素除外)
2.行内、块级元素区别:
1,块级元素独占一行,其宽度自动填满父元素宽度
行内元素不独占一行,相邻行内元素排在同一行,直到排不下,才换行,其宽度随元素的内容而变化
2,一般情况下,块级元素可设置 width, height属性,行内元素设置width, height无效(置换元素除外)
(注意:块级元素即使设置了宽度,仍然是独占一行的)
3,块级元素可以设置margin 和 padding. 行内元素的水平方向的padding-left,padding-right,margin-left,margin-right 都产生边距效果,但竖直方向的padding-top,padding-bottom,margin-top,margin-bottom都不会产生边距效果。(水平方向有效,竖直方向无效)
3.行内、块级元素:
常见块级元素(block element)
address - 地址
center - 居中对齐块
div - 常用块级元素,也是css layout的主要标签
dl - 定义列表
form - 交互表单
h1 - 大标题
h2 - 副标题
h3 - 3级标题
h4 - 4级标题
h5 - 5级标题
h6 - 6级标题
hr - 水平分隔线
menu - 菜单列表
ol - 有序列表
ul - 无序列表
li - 列表项
p - 段落
pre - 格式化文本
table - 表格
tr - 表格中的行
常见内联元素(inline element)
a - 锚点
b - 粗体(不推荐)
big - 大字体
br - 换行
dfn - 定义字段
em - 强调
i - 斜体
img - 图片
input - 输入框
label - 表格标签
q - 短引用
select - 项目选择
span - 常用内联容器,定义文本内区块
strong - 粗体强调
textarea - 多行文本输入框
u - 下划线
var - 定义变量
4.行内元素和块级元素之间的转换
1.设置display
块级元素,默认display:block;
行内不可置换元素,默认为display:inline;
行内置换元素,默认为display:inline-block;
display:none;不显示该元素,也不会保留该元素原先占有的文档流位置。
display:block;转换为块级元素。
display:inline;转换为行内元素。
display:inline-block;转换为行内块元素。
2.设置float
当把行内元素设置完浮动(float:left/right)后,该行内元素的display属性会被赋予block值,且拥有浮动特性。(当它浮动时,行内元素就会生成一个块级框。也可以说是行内框)与此同时,行内元素去除了之间的莫名空白。
3.设置position
当为行内元素进行定位时,position:absolute,与position:fixed。都会使原先的行内元素变为块级元素。
注意
转换为块级元素只是,float与position的副作用,他们本身的作用还会干扰布局效果。
介绍块级元素时,会说,块级元素的宽度会继承其父元素。但是,只有为行内元素设置display:block;才会有这样的效果,其他转换之后并不会默认带来这个效果。