`
liuxiang822
  • 浏览: 47893 次
  • 性别: Icon_minigender_1
  • 来自: 常州
社区版块
存档分类
最新评论

测试inline元素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;}            
        </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两者区别探讨

    在CSS布局中,`display:inline` 和 `float:left` 是两个重要的属性,它们分别用于不同的布局策略,但有时也会一起使用以实现特定的设计效果。下面将详细解释这两个属性的含义和区别。 首先,`display:inline` 是一...

    inline-block带来的元素间距问题解决

    本文主要关注`inline-block`元素的间距问题及其解决方案,同时也会对比`block`和`inline`的特性。 首先,`display: inline-block` 是一种混合型布局模式,它结合了`inline`元素的并排显示特性与`block`元素的宽高...

    css之display属性之inline-block布局实现详解

    - **不同之处**:`display: inline-block`不会让元素脱离正常文本流,而`float`会。`float`会导致父元素高度塌陷,需要额外的清理方法来恢复。 - **相同之处**:两者都可以实现类似的效果,使元素并排显示。 - **...

    css 块状元素和内联元素

    在增加`#div3`这个蓝色块状元素后,由于块状元素的特性,它会另起一行显示,而不是与`#div2`并排。 需要注意的是,虽然块状元素主要用作容器,但它们还有其他用途。例如,可以通过设置适当的边距(margin)和填充...

    HTML 38 道面试题及答案.docx

    2. display:inline-block 可以让元素变为行内块元素。 3. transform:translate(-50%,-50%) 可以让元素水平和垂直居中。 通过本文档,我们可以了解到 HTML 中的一些基本概念和常见问题的答案,并能够更好地使用 ...

    《HTML5网页设计》练习4.pdf

    4. `display`属性可以转换元素的类型,例如将块元素变为行内元素使用`display:inline`,反之则使用`display:block`。 5. `background-image`属性用于将图像设置为网页元素的背景。 二、概念辨析 1. 行内元素可以...

    HTML5+CSS3开发商业站点Chapter7.pptx

    - **会使用display属性排版网页元素**:掌握如何通过`display`属性控制元素的显示状态(如`block`、`inline`、`inline-block`、`none`),实现块级元素与行级元素之间的转换。 - **会使用float属性排版网页元素**:...

    多个div能不换行吗?

    1. **使用 `display: inline-block`**:将每个 `div` 的 CSS 类设置为 `display: inline-block`,这将使 `div` 元素变为类似文本的元素,可以在同一行内排列,但仍然保留块级元素的特性,如设置宽高。例如: ```css...

    css中替换元素和不可替换元素及显示元素详细探讨

    但要注意,设置了浮动(`float`)的元素虽仍属于块级元素,但可以与其他元素并列,而`list-item`则会在前面添加项目符号或编号。 **行内元素**则不会单独占据一行,它们可以和其他行内元素并列出现在同一行内,如`...

    Basic Visual Formatting in CSS

    3. **内联块盒子(Inline-Block Box)**:结合了块级元素和内联元素的特点,可以并排显示且支持设置宽度、高度等属性。 4. **列表项盒子(List-Item Box)**:列表项元素通常表现为块级元素,并可包含前导符号或图像...

    css中display:block;的用法及适用标签详解

    此外,在使用浮动布局(float layout)时,清除浮动后,有时也需要重置`display`属性为`block`来恢复元素的正常流布局。 总之,`display: block;`是一个非常灵活的CSS属性,它可以改变元素的显示方式,使其适应各种...

    关于html元素的 width属性无效果的解决方法

    只有块级元素(例如`div`)或具有特定CSS属性(如`display: block`、`display: inline-block`或`float`)的元素才会响应`width`和`height`属性。 1. **解决方案一:**移除W3C标准声明(不推荐)。虽然可以通过取消...

    Span元素的width属性无效果原因及解决方案

    2. 将 Span 元素的 display 属性设置为 block,这样可以使得 width 属性生效,但是这样的话,Span 元素就变成了块级元素,和 div 元素一样了。 3. 将 Span 元素的 display 属性设置为 inline-block,这样可以使得 ...

    margin值在IE6变成双倍

    标题中的“margin值在IE6变成双倍”指的是在Internet Explorer 6(简称IE6)浏览器中,当设置元素的外边距(margin)时,可能会遇到一个知名的兼容性问题,即所谓的“双边距问题”(Double Margin Bug)。这个问题主要...

    浅谈CSS中display/float/position属性值的相互影响

    2. 当`position`为`absolute`或`fixed`时,`float`的计算值变为`none`,元素将脱离正常文档流,`display`的值会根据CSS规范调整,通常变成`block`或`inline-block`。 3. 如果`float`不是`none`,元素会浮动,`...

    跨浏览器兼容CSS篇整理.pdf

    例如,设置`display:block`可以使内联元素变为块级,反之亦然。内联元素的垂直对齐可以通过`vertical-align`属性进行控制,而块级元素则不能。 浮动(float)属性是创建多列布局的常用工具,它可以将元素向左或向右...

    昨日测试题答案 大家可以对照下

    `border-radius`设置圆角,`display`控制元素显示方式(如`block`或`inline`),`position`设定元素定位(如`relative`、`absolute`或`fixed`),`width`和`height`设置元素尺寸,`float`实现浮动布局,`overflow`...

    笔记156111

    然而,通过改变`display`属性的值,可以改变元素的显示方式,比如将内联元素变为块级元素(`display: block`),或者反之(`display: inline`)。 此外,HTML提供多种内置元素,如`&lt;address&gt;`(地址)、`...

    css基础教程pdf 思维导图

    在标准文档流中,元素分为inline、inline-block和block三类。行内元素会被浏览器视为文本处理,块级元素会占据整行。`display`属性用于切换元素的行为。`float`常用于创建自适应布局,`clear`则用于控制元素是否跟随...

Global site tag (gtag.js) - Google Analytics