为什么在元素设置float之后就可以改变宽和高了呢?

今天一个朋友说遇到一个面试题,无论是何种元素(inline,inline-block,block)在设置float之后,都可以改变他的宽度和高度了。做前端这么久我竟然都没思考过这个问题。下面一个小小例子,测试一下。

<div>
    <span>首页</span>
    <span>关于</span>
    <span>冷知识库</span>
    <span>为了凑数</span>
</div>
div span{
           color:green;
           margin-right: 10px;
           background: #c9e2b3;
        }

效果图:




现在这种情况下 ,如果想让他们看起来好看点只能设置padding来扩充,因为span是行内元素,无法设置宽度和高度,全靠里面的内容撑起来。

接下来,我们开始让他们浮动。在样式中加了这些代码

 div span{
            color:green;
            margin-right: 10px;
            background: #c9e2b3;
            float: left;
            width: 150px;
            height: 50px;
            line-height: 50px;
            text-align: center;
        }
效果图是:


现在已经很明显能看出来了。因为你如果想利用padding达到这种效果的话,需要单独设置每一个span,还得计算不同的padding,可想而知。。。

为了更直观的看出来 ,是否span真的变成了block元素,我又加了一行验证代码:

span真的变成了block元素。

另外 position:absolute;fixed;relative;也可以将元素变成block元素。

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值