js显示隐藏 display visibility以及jquery里的show hide的区别

简介: js显示隐藏 display visibility以及jquery里的show hide的区别

display和visibility都是css样式,而show hide则是jquery的方法

display

描述
none 此元素不会被显示。
block 此元素将显示为块级元素,此元素前后会带有换行符。
inline 默认。此元素会被显示为内联元素,元素前后没有换行符。
<style>
        body{
            border: 1px solid black;
        }
        #a1{
            display: none;
        }
    </style>
</head>
<body>
    <div id="a1" style="background-color:red; height: 30px; width: 30px;"></div>
    <div id="a2" style="background-color:yellow;height: 30px; width: 30px;">
    </div><div id="a3" style="background-color:blue;height: 30px; width: 30px;"></div> </div>
</body>

image.gif

image.gif编辑

给a1设置display隐藏之后,剩下了黄色和蓝色,并且黄色变成了第一个

visibility

visible 默认值。元素是可见的。
hidden 元素是不可见的。
collapse 当在表格元素中使用时,此值可删除一行或一列,但是它不会影响表格的布局。被行或列占据的空间会留给其他内容使用。如果此值被用在其他的元素上,会呈现为 "hidden"。
inherit 规定应该从父元素继承 visibility 属性的值。
<style>
        body{
            border: 1px solid black;
        }
        #a1{
            /* display: none; */
            visibility: hidden;
        }
    </style>
</head>
<body>
    <div id="a1" style="background-color:red; height: 30px; width: 30px;"></div>
    <div id="a2" style="background-color:yellow;height: 30px; width: 30px;">
    </div><div id="a3" style="background-color:blue;height: 30px; width: 30px;"></div> </div>
</body>

image.gif

image.gif编辑

同样只是生下了黄色和蓝色,但是保留了红色位置。

这是为什么呢?

display属性应用之后会引起页面的重塑和回流,而visibility只会引起重塑不会回流,

通俗讲就是 display隐藏之后自己的位置没有了,visibility隐藏之后虽然东西没了,但还站着原来的位置。

hide show

<style>
        body{
            border: 1px solid black;
        }
        #a1{
            /* display: none; */
            /* visibility: hidden; */
        }
    </style>
    <script src='http://libs.baidu.com/jquery/2.1.1/jquery.min.js'></script>
    <script>
        $(function(){
            $('#a1').hide();
        })
    </script>
</head>
<body>
    <div id="a1" style="background-color:red; height: 30px; width: 30px;"></div>
    <div id="a2" style="background-color:yellow;height: 30px; width: 30px;">
    </div><div id="a3" style="background-color:blue;height: 30px; width: 30px;"></div> </div>
</body>

image.gif

image.gif编辑

这次我们使用了hide方法,跟display一样剩下了黄色和蓝色的div并且黄色跑到了顶部,

其实hide方法就相当于display none隐藏,不会保留原位置。

那么如果都设置了谁的级别更高呢?

<style>
        body{
            border: 1px solid black;
        }
        #a1{
            visibility: visible;
            display: none;
        }
    </style>
    <script src='http://libs.baidu.com/jquery/2.1.1/jquery.min.js'></script>
    <script>
        // $(function(){
        //     $('#a1').hide();
        // })
    </script>
</head>
<body>
    <div id="a1" style="background-color:red; height: 30px; width: 30px;"></div>
    <div id="a2" style="background-color:yellow;height: 30px; width: 30px;">
        <div id="a3" style="background-color:blue;height: 30px; width: 30px;"></div> </div>
    </div>

image.gif

image.gif编辑

红色隐藏了,是不是说display的级别更大呢?

我们试试visibility的隐藏

<style>
        body{
            border: 1px solid black;
        }
        #a1{
            visibility: hidden;
            display: block;
        }
    </style>
    <script src='http://libs.baidu.com/jquery/2.1.1/jquery.min.js'></script>
    <script>
        // $(function(){
        //     $('#a1').hide();
        // })
    </script>
</head>
<body>
    <div id="a1" style="background-color:red; height: 30px; width: 30px;"></div>
    <div id="a2" style="background-color:yellow;height: 30px; width: 30px;">
    </div>
    <div id="a3" style="background-color:blue;height: 30px; width: 30px;"></div> </div>
</body>

image.gif

image.gif编辑

这下是visibility的隐藏起作用了  那究竟是谁的级别更高呢

个人认为:谁隐藏谁级别就高,会优先执行隐藏属性,display隐藏就使用display回流,visibility隐藏就使用visibility不回流。

相关文章
|
27天前
|
JavaScript
鼠标事件(点击换色)分别使用js和jQuery代码实现
鼠标事件(点击换色)分别使用js和jQuery代码实现
28 1
|
27天前
|
JavaScript 前端开发 索引
js的循环中foreach、for in和for of的区别
js的循环中foreach、for in和for of的区别
93 0
|
6天前
|
前端开发 JavaScript API
JavaScript 的宏任务和微任务有什么区别
【9月更文挑战第6天】JavaScript 的宏任务和微任务有什么区别
14 4
|
20天前
|
JavaScript
分别用jquery和js修改页面元素
分别用jquery和js修改页面元素
27 2
|
27天前
|
JavaScript Java
点击按钮,向下添加目录。Java script+jQuery写法
点击按钮,向下添加目录。Java script+jQuery写法
12 1
|
27天前
|
JavaScript Java
分别使用js与jquery写 单击按钮时出现内容 点击删除按钮不会再向下出现
分别使用js与jquery写 单击按钮时出现内容 点击删除按钮不会再向下出现
15 1
|
11天前
|
存储 JavaScript 前端开发
|
11天前
|
Devops 持续交付 测试技术
JSF遇上DevOps:开发流程将迎巨变?一篇文章带你领略高效协同的魅力!
【8月更文挑战第31天】本文探讨了如何在JavaServer Faces(JSF)开发中融入DevOps文化,通过持续集成与部署、自动化测试、监控与日志记录及反馈机制,提升软件交付速度与质量。文中详细介绍了使用Jenkins进行自动化部署、JUnit与Selenium进行自动化测试、ELK Stack进行日志监控的具体方法,并强调了持续改进的重要性。
22 0
|
21天前
|
JavaScript 前端开发 Java
Java和JavaScript区别与联系
【8月更文挑战第18天】
|
27天前
|
XML JSON 前端开发
AJAX是什么?原生语法格式?jQuery提供分装好的AJAX有什么区别?
AJAX是什么?原生语法格式?jQuery提供分装好的AJAX有什么区别?
26 0