快盘下载:好资源、好软件、快快下载吧!

快盘排行|快盘最新

当前位置:首页软件教程电脑软件教程 → display: none、visibility: hidden和opacity: 0的区别

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

时间:2022-09-29 13:46:31人气:作者:快盘下载我要评论

是否脱离文档流

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

是否继承可见性

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

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

<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的区别

是否响应事件

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

示例如下:

<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>

结果如下:

网友评论

快盘下载暂未开通留言功能。

关于我们| 广告联络| 联系我们| 网站帮助| 免责声明| 软件发布

Copyright 2019-2029 【快快下载吧】 版权所有 快快下载吧 | 豫ICP备10006759号公安备案:41010502004165

声明: 快快下载吧上的所有软件和资料来源于互联网,仅供学习和研究使用,请测试后自行销毁,如有侵犯你版权的,请来信指出,本站将立即改正。