CSS之元素隐藏属性对比:overflow: hidden; visibility: hidden; display: none;

相同:三者都能使元素隐藏。

区别:

  • overflow: hidden;溢出隐藏。这个说是隐藏,倒不如说是裁剪,把超出显示的区域裁剪掉,与clip类似。

  • visibility: hidden;隐藏可见性。这个是把元素隐藏掉,相当于100%透明,不可见,但是还是占位置,占空间。(相当于哈利波特披上隐形斗篷,他还能碰到物体)
  • display: none;不显示。这个隐藏看不见也不占空间。

  1. 元素先visibility: hidden;隐藏,再通过visibility: visible;显示出来,这个方法占空间的,无论在隐藏时还是被显示时。
  2. 元素先display: none;隐藏,再通过display: block;显示出来,这个方法不占空间,无论在隐藏时还是被显示时。
    在这里插入图片描述在这里插入图片描述
<!DOCTYPE html>
<html>
<head> 
<meta charset="utf-8"> 
<title></title>
<style type="text/css">
body, p {
    padding: 0;
    margin: 0;
}

.container {
    min-width: 100%;
    min-height: 100%;
    background: #fcc;
    position: absolute;
}

.wrap {
    width: 500px;
    height: 300px;
    margin: 0 auto;
}

.wrap p {
    color: blue;
    font-size: 20px;
    font-weight: bold;
}

.wrap .child {
    width: 200px;
    height: 200px;
}

.wrap .add-visibility {
    background: red;
    /*visibility: hidden;*/
}

.wrap .add-display {
    background: yellow;
    /*display: none;*/
}
</style>
</head> 
<body>
    <div class="container">
        <div class="wrap">
            <p>visibility隐藏显示测试,测试元素为红色</p>
            <div class="child add-visibility">这是测试部分</div>
            <div class="child-brother">这是兄弟元素,检测是否占位</div>
        </div>
        <div class="wrap">
            <p>display隐藏显示测试,测试元素为黄色</p>
            <div class="child add-display">这是测试部分</div>
            <div class="child-brother">这是兄弟元素,检测是否占位</div>
        </div>
    </div>
</body>
</html>
display: none、visibility: hidden和opacity: 0是用于隐藏元素的三种CSS属性。它们之间有一些区别。 display: none会完全移除该元素在页面上的存在,不仅看不见,也无法交互和占据空间。换句话说,该元素在页面布局中没有留下任何痕迹。 visibility: hidden会使元素变得不可见,但仍然会占据它在页面布局中的空间。虽然不能看到该元素,但它会影响周围元素的布局。 opacity: 0会将元素的透明度设置为0,从而使元素完全透明。与display: none不同,该元素仍然存在于页面上,并且会占据空间,但用户无法看到它。但是该元素仍然能够响应用户的交互。 这三种属性隐藏效果和行为不同,可以根据具体需求选择使用。如果希望完全删除元素并且不占据空间,可以使用display: none。如果希望元素不可见但仍然占据空间,可以使用visibility: hidden。如果希望元素透明但仍然存在并能够交互,可以使用opacity: 0。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [CSS隐藏属性display:none;visibility:hiddenoverflow:hidden](https://blog.csdn.net/Jorpeng/article/details/127570390)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [display:none](https://blog.csdn.net/harry5508/article/details/81904533)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值