行内元素(inline)也叫内联,内嵌元素:
1.内容撑开宽高
宽高值都是auto,显示出来的宽高是内容撑开的
2.不支持宽高设置
3.不支持上下的margin与上下padding(显示的距离不是正确的)
支持左右
4.所有的行内元素都会在一行显示
5.代码换行会被解析成一个空格(一个空格的大小是字体的一般,例如:宋体是16px,则空格是8px)
因为div是块元素,默认是独占一行的。因此要两个div块并行的话可以使用 float 或则display
行内元素与块元素的互换display(能不用就不要用)
(1) 块元素转行内元素 display:inline;
转换后块元素就具有了行内元素的特征。
(2)行内元素转换块元素display:block;
转换后行内元素就具有块元素的特征
(3)使元素同时具块元素和行内元素特征 display:inline-block;
1.行内元素支持宽高
2.块元素可以在同行中显示
3.不给宽高的话,宽度会由内容撑开
4.编辑器换行会被解析成一个空格
5.IE6、7不支持块元素的inline-block
IE6、7不认识inline-block,给行内元素加上这个属性后会触发IE的haslayout特点,
使得可以显示行内元素inline-block,但是不能显示块元素的inline-block

这里因为一个是块元素,另一个是行内元素,所以只需要在快元素加display
情景代码如上。
出问题的浏览器:
360,sogou,猎豹的极速模式
给DIV设置display:inline-block属性后,这四个DIV会拍在一排,但是会个别的高一点,不对齐。
解决方法:
给div设置vertical-align:top
先用vertical-align:xx;使其中一个的值为零,然后用margin来确定。
aaaaa
bbbb
(3)如果这两个块元素还有一个父级, 当两个快元素的宽加起来>父级的宽,也是不能在同一行显示的。
但是当两个块元素加起来刚好等于父级也不能在同一行显示,因为在编辑器写时两个子标签已经折行,
除非是将两个子标签写在同一行。
或者
给父级样式加上一个font-size:0px; (但是子标签的文字需要有自己的大小,否则会被父级这个标签影响)
font-size:0px;的效果就是去除间隙
<style>
div{ font-size:0px; }
h2{ font-size:15px;
display:inline-block;}
a{ font-size:15px; }
</style>
<div>
<h2>aaaaa</h2>
<a>bbbb</a>
</div>