display:inline,display:inline-block,display:block 区别
之前一直迷惑于display:inline/inline-block/block的异同,在度娘谷哥的帮助下,突然有了一点思路。
按照网上的介绍,inline将对象转化为内联元素,block将对象转化为块元素,而inline-block则将对象转化为具有块属性的内联元素。
可能是因为本人理解能力有限,一直很纠结着难以理解这个说法。后来看到这么一个解释[1]:
内联元素即所有元素都在一行上,无前后换行符,且无法限定高宽,即高宽为其内容的高宽。例如<input>,<img>,<span>,<em>都是内联元素的例子。
块元素即总在新行上开始,可控制高宽。<div>,<p>,<form>,<h1>为块元素的例子。
从例子上说,对span进行背景色限定时,会发现span的背景色总是和文字大小相符,即说明了内联元素的特性。而对div增加背景色限定,则可无视其内容,根据div的高宽进行渲染。
但是,如果需要对span进行背景色限定,但又要对span的大小做规定,那就用到了inline-block。
<html>
<head>
<style>
#content{width:auto;height:200px;}
.blockdiv{background:#ccc;width:50%;height:50px;}
.inlinespan{background:#f60;width:50%;height:50px;}
</style>
</head>
<body>
<div id="content">
<div class="blockdiv">这段文字用于测试div的大小</div><span class="inlinespan">这段文字用于测试span的大小
</span>
</div>
</body>
</html>
例如上面这个例子,假如想使div.blockdiv和span.inlinespan在一行,但又希望控制div.blockdiv的高度,即可使用div.blockdiv{display:inline-block;}
inline-block即将对象对外转换为内联元素,但对内其内容又可限定高宽,具有块元素的特征属性。这样一来,规定了inline-block的元素会和周围inline的元素在一行,但它又可以指定高宽。
仍旧是万恶的IE,IE6/7对inline-block的支持不够完善。因此需要采用hack的方式,但首先需要明了这种hack的原理:
这是IE的一个经典bug,如果先定义了display:inline-block,然后再设置display回inline或block,layout不会消失。但需要在两个css中[2]。
IE6/7可识别的hack为*,IE6为_。参考[3,4]后,认定在现在IE6/7下的inline-block可通过以下原理实现。在IE中的方式有以下几种,例如object
1、#object{
display:inline-block;//激活inline-block,使之在除IE8/7/6下的浏览器均实现,同时使IE下元素触发block
zoom:1;//激活IE下的对象haslayout属性
}
#object{
*display:inline;//IE6/7下的对象在保持有haslayout属性前提下,表现为inline
}
2、#object{
float:left;//触发layout,表现为块元素
display:inline;//使之产生inline效果
}
3、#object{
display:inline; //先使对象呈内联状态
zoom:1; //激活layout
}
因此,display:inline-block在IE中的hack可表现为:
1、为对象增加haslayout属性,使之表现为块元素
2、将对象转换为inline.(haslayout不消失)
3、顺序可颠倒。
参考:
1.http://www.cnblogs.com/jdonson/archive/2011/06/10/2077932.html
2.http://ideal.ncepu.me/2012/03/25/1-182/
3.http://www.68design.net/Web-Guide/HTMLCSS/41207-4.html
4.http://www.codesky.net/article/201107/169482.html
display:inline,display:inline-block,display:block 区别的更多相关文章
- display:inline block inline-block 的区别
原文地址:http://blog.csdn.net/jly036/article/details/5506182 display:block就是将元素显示为块级元素. block元素的特点是: 总是在 ...
- display:inline、block、inline-block区别
display:inline.block.inline-block区别 display:block就是将元素显示为块级元素. display:inline就是将元素显示为行内元素. inline-bl ...
- block与inline,inline和inline-block,块级和行内元素,行内替换和行内非替换元素
block:块级元素默认display属性为block:无论块内内容有多少,总是占满一行: inline:行内元素默认display属性为inline:只占据块内的内容的大小,不会占满一整行: inl ...
- Initialization failed for block pool Block pool(转载)
2014-06-18 20:34:59,622 FATAL org.apache.hadoop.hdfs.server.datanode.DataNode: Initialization failed ...
- style.display = "inline或inline";和style.display = "";的区别
function a(){ if($('#b').attr('checked')){ $('.c').css("display",""); //"di ...
- inline,block,inline-block的区别
display:block block元素会独占一行,多个block元素会各自新起一行.默认情况下,block元素宽度自动填满其父元素宽度. block元素可以设置width,height属性.块级元 ...
- Block formatting context & Inline formatting context(BFC&IFC)的区别(转载)
何为BFC与IFC bfc与ifc是针对页面正常流的两种环境,块级元素处于bfc环境中,行内元素处于ifc环境中. 元素是块级元素or行内元素由其display属性决定: block, table, ...
- td高度不随内容变化display:block;display:block;display:block;display:block;display:block;
在TD里加个DIV就可以解决!CSS对应改成#aaa td div{ height:236px; overflow:hidden; 在TD里加个DIV就可以解决!CSS对应改成#aaa td div{ ...
- display:inline-block的div 与 display:block的div之间有间隔问题(div与div之间有间隔的可能性)
首先看一下我出现的问题如下图: 如上图所示,我的导航栏是由三部分组成的,三部分样式如下: .logo{ /*红框*/ position: relative; display: inline-block ...
- display:none与visibility:hidden区别
display:none与visibility:hidden有一个共同的作用是隐藏要显示的内容isplay:none 隐藏,但是不占空间 “看不见摸不到” 加载 display:none 隐藏,但是不 ...
随机推荐
- SQLSERVER一个比较不错的分页存储过程p_splitpage
CREATE procedure p_splitpage @sql nvarchar(4000), --要执行的sql语句 @page int=1, --要显示的页码 @pageSize int, - ...
- X-SCAN扫描器插件(MYSQL弱口令以及Mongodb未授权)
因为在很多时候的内网扫描里面没有授权的WIN的好用的,稍微小点的弱口令扫描器(生成报告,多种服务),编译成了插件,再自己弄了个MONGODB的扫描插件用着. X-SCAN加载以后: MONGODB.p ...
- jquery 获取选中的文字.当前光标所在的位置等jquery-fieldselection 插件
写词典在线编辑器用到的一个功能 能获取选中的文字.当前的光标的位置 等位置,而且支持多个文本框一起操作 非常方便 git地址:https://github.com/localhost/jquery-f ...
- 开发者应该避免使用的6个Java功能(转)
本文作者是一名拥有多年Java开发经验的程序员,他从经验中得出,并不是所有的Java SE功能/API都值得程序员去使用,比如本文列举的这6个,大家在使用前得慎重对待.以下是对原文的摘译. 多年的Ja ...
- db file sequential read等待事件的一点研究
db file sequential read等待事件有3个参数:file#,first block#,和block数量. 这个等待事件有3个参数P1,P2,P3, 其中P1代表Oracle要读取的文 ...
- POJSorting It All Out (拓扑)
题目链接. 题目大意: 给定一定的数量的小于关系: 1.如果发现环,输出从前几次就可以确定出现环 2.如果能够确定唯一序列,输出. 3.如果通过全部关系,还不能确定序列,则输出不能确定. 分析: 个人 ...
- C语言---递归反向输出任意长度的字符串
(该字符串可以包含空格和回车!) [题目要求] 编写一个递归函数,实现将输入的任意长度的字符串反向输出的功能. 例如输入字符串:ABCD,输出字符串:DCBA. [题目分析] 应用递归的思想有时可以很 ...
- Foundation Data Structure
LinkedList : /** * 考虑的比较的周全,并且包含了全部的情况,代码也不乱<b></b> * * @param index * 插入的位置 * @param c ...
- 在windows下MySQLdb/MySQL-python的安装
学习Python的时候总是遇到各种各样的问题,很多问题我也百度了很久,谷歌了很多,发现很多人也遇到这种问题:但是答案又各种不同,因人而异吧! 问题:windows系统下 安装了mysql数据库 ...
- 关于“无法解析的外部符号”和“该符号在函数_wmain 中被引用”的问题
在VS2008和opendv的环境下: error LNK2019: 无法解析的外部符号_cvDestroyWindow,该符号在函数_wmain 中被引用 error LNK2019: 无法解析的外 ...