前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >display: none、visibility: hidden和opacity: 0的区别

display: none、visibility: hidden和opacity: 0的区别

作者头像
lonelydawn
发布2022-09-27 19:10:04
7950
发布2022-09-27 19:10:04
举报

是否脱离文档流

  • display: none:元素将脱离文档流,不占据原来的空间,会引起页面的重排
  • visibility: hidden:不会脱离文档流,元素不可见仍然占据原来的位置
  • opacity: 0:不会脱离文档流,元素不可见仍然占据原来的位置

是否继承可见性

display: none 和 opacity: 0,子元素会和父元素一样保持不可见。

visibility: hidden 的父元素下,若子元素设为 visibility: visible,则父元素不可见,子元素可见。示例如下:

代码语言:javascript
复制
<style type="text/css">
    .parent {
        visibility: hidden;
        width: 300px;
        height:  300px;
        background-color: #2468F2;
    }

    .child {
        visibility: visible;
        width: 200px;
        height:  100px;
        background-color: #CCC;
    }
</style>
<div class="parent">
    <div class="child">child</div>
<div>

结果如下: 

是否响应事件

  • display: none元素都不在文档流中了,不会响应事件
  • visibility: hidden 的元素也不会响应事件
  • opacity: 0 的元素可以响应事件

示例如下:

代码语言:javascript
复制
<style type="text/css">
    .box {
        display: inline-block;
        font-size: 48px;
        width: 300px;
        height: 300px;
    }
    .box:active {
        cursor: wait;
    }

    #opacity {
        background-color: #F00;
    }
    #visibility {
        background-color: #00F;
    }
</style>
<div id="opacity" class="box">opacity</div>
<div id="visibility" class="box">visibility</div>

<button onclick="setHidden()">设置不可见</button>

<script type="text/javascript">
    const opacityEl = document.getElementById('opacity');
    const visibilityEl = document.getElementById('visibility');

    function setHidden() {
        opacityEl.style.opacity = 0;
        visibilityEl.style.visibility = 'hidden';
    }

    opacityEl.onclick = function () {
        alert('click');
    }
    visibilityEl.onclick = function () {
        alert('click');
    }
</script>

结果如下:

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-08-31,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 是否脱离文档流
  • 是否继承可见性
  • 是否响应事件
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档