首先用span标签做下测试,贴上代码先
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>测试span float后是否会变为block元素</title>
<style>
body{ font:12px Arial, Helvetica, sans-serif; background:#FFF;}
.d_a,.s_a{border:1px solid #CCC;}
.d_a{width:300px;height:200px;margin:50px auto 0;}
.s_a{float:left;background:#EEE;margin-left:10px;}
</style>
</head>
<body>
<div class="d_a">
<span class="s_a">我是span标签</span>
</div>
</body>
</html>
.s_a有个margin-left,并且没有给其加display:inline,如果float后span变为block,那么这时IE6下就会出现双倍margin,下为IE6下的截图:
很明显.s_a的margin还是10相素,并没有出现IE6下两倍margin的情况!这是怎么回事,难道span float后还是inline,没有block吗?让我们继续深入测试,大家都知道inline元素给其加width、height是无效的,那么现在就简单了,要想证明span float后是否block只需再给span加上宽度或者高度试下,代码如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>测试span float后是否会变为block元素</title>
<style>
body{ font:12px Arial, Helvetica, sans-serif; background:#FFF;}
.d_a,.s_a{border:1px solid #CCC;}
.d_a{width:300px;height:200px;margin:50px auto 0;}
.s_a{float:left;background:#EEE;margin-left:10px;width:200px;height:50px;}
</style>
</head>
<body>
<div class="d_a">
<span class="s_a">我是span标签</span>
</div>
</body>
</html>
最终结果如下图(来自IE6)
很明显span float后宽度、高度对其有影响了,结果应该是span标签 float后block了,但是本身的inline并没有丢!(既可设宽度、高度,IE6中又没有出现双倍margin) 这里只测试了<span>我想<a>标签之类的其它inline标签也是同样的情况。最后再说明一点:本身自带inline元素的标签在float和margin同时使用的情况下,不用担心会出现双倍margin,并不需要再特意加上display:inline!
分享到:
相关推荐
在CSS布局中,`display:inline` 和 `float:left` 是两个重要的属性,它们分别用于不同的布局策略,但有时也会一起使用以实现特定的设计效果。下面将详细解释这两个属性的含义和区别。 首先,`display:inline` 是一...
本文主要关注`inline-block`元素的间距问题及其解决方案,同时也会对比`block`和`inline`的特性。 首先,`display: inline-block` 是一种混合型布局模式,它结合了`inline`元素的并排显示特性与`block`元素的宽高...
- **不同之处**:`display: inline-block`不会让元素脱离正常文本流,而`float`会。`float`会导致父元素高度塌陷,需要额外的清理方法来恢复。 - **相同之处**:两者都可以实现类似的效果,使元素并排显示。 - **...
在增加`#div3`这个蓝色块状元素后,由于块状元素的特性,它会另起一行显示,而不是与`#div2`并排。 需要注意的是,虽然块状元素主要用作容器,但它们还有其他用途。例如,可以通过设置适当的边距(margin)和填充...
2. display:inline-block 可以让元素变为行内块元素。 3. transform:translate(-50%,-50%) 可以让元素水平和垂直居中。 通过本文档,我们可以了解到 HTML 中的一些基本概念和常见问题的答案,并能够更好地使用 ...
4. `display`属性可以转换元素的类型,例如将块元素变为行内元素使用`display:inline`,反之则使用`display:block`。 5. `background-image`属性用于将图像设置为网页元素的背景。 二、概念辨析 1. 行内元素可以...
- **会使用display属性排版网页元素**:掌握如何通过`display`属性控制元素的显示状态(如`block`、`inline`、`inline-block`、`none`),实现块级元素与行级元素之间的转换。 - **会使用float属性排版网页元素**:...
1. **使用 `display: inline-block`**:将每个 `div` 的 CSS 类设置为 `display: inline-block`,这将使 `div` 元素变为类似文本的元素,可以在同一行内排列,但仍然保留块级元素的特性,如设置宽高。例如: ```css...
但要注意,设置了浮动(`float`)的元素虽仍属于块级元素,但可以与其他元素并列,而`list-item`则会在前面添加项目符号或编号。 **行内元素**则不会单独占据一行,它们可以和其他行内元素并列出现在同一行内,如`...
3. **内联块盒子(Inline-Block Box)**:结合了块级元素和内联元素的特点,可以并排显示且支持设置宽度、高度等属性。 4. **列表项盒子(List-Item Box)**:列表项元素通常表现为块级元素,并可包含前导符号或图像...
此外,在使用浮动布局(float layout)时,清除浮动后,有时也需要重置`display`属性为`block`来恢复元素的正常流布局。 总之,`display: block;`是一个非常灵活的CSS属性,它可以改变元素的显示方式,使其适应各种...
只有块级元素(例如`div`)或具有特定CSS属性(如`display: block`、`display: inline-block`或`float`)的元素才会响应`width`和`height`属性。 1. **解决方案一:**移除W3C标准声明(不推荐)。虽然可以通过取消...
2. 将 Span 元素的 display 属性设置为 block,这样可以使得 width 属性生效,但是这样的话,Span 元素就变成了块级元素,和 div 元素一样了。 3. 将 Span 元素的 display 属性设置为 inline-block,这样可以使得 ...
标题中的“margin值在IE6变成双倍”指的是在Internet Explorer 6(简称IE6)浏览器中,当设置元素的外边距(margin)时,可能会遇到一个知名的兼容性问题,即所谓的“双边距问题”(Double Margin Bug)。这个问题主要...
2. 当`position`为`absolute`或`fixed`时,`float`的计算值变为`none`,元素将脱离正常文档流,`display`的值会根据CSS规范调整,通常变成`block`或`inline-block`。 3. 如果`float`不是`none`,元素会浮动,`...
例如,设置`display:block`可以使内联元素变为块级,反之亦然。内联元素的垂直对齐可以通过`vertical-align`属性进行控制,而块级元素则不能。 浮动(float)属性是创建多列布局的常用工具,它可以将元素向左或向右...
`border-radius`设置圆角,`display`控制元素显示方式(如`block`或`inline`),`position`设定元素定位(如`relative`、`absolute`或`fixed`),`width`和`height`设置元素尺寸,`float`实现浮动布局,`overflow`...
然而,通过改变`display`属性的值,可以改变元素的显示方式,比如将内联元素变为块级元素(`display: block`),或者反之(`display: inline`)。 此外,HTML提供多种内置元素,如`<address>`(地址)、`...
在标准文档流中,元素分为inline、inline-block和block三类。行内元素会被浏览器视为文本处理,块级元素会占据整行。`display`属性用于切换元素的行为。`float`常用于创建自适应布局,`clear`则用于控制元素是否跟随...