• 分析比较 opacity: 0、visibility: hidden、display: none 优劣和适用场景


    总结: 

      结构: display:none: 会让元素完全从渲染树中消失,渲染的时候不占据任何空间, 不能点击, visibility: hidden:不会让元素从渲染树消失,渲染元素继续占据空间,只是内容不可见,不能点击 opacity: 0: 不会让元素从渲染树消失,渲染元素继续占据空间,只是内容不可见,可以点击

      继承: display: none和opacity: 0:是非继承属性,子孙节点消失由于元素从渲染树消失造成,通过修改子孙节点属性无法显示。 visibility: hidden:是继承属性,子孙节点消失由于继承了hidden,通过设置visibility: visible;可以让子孙节点显式。

      性能: displaynone : 修改元素会造成文档回流,读屏器不会读取display: none元素内容,性能消耗较大 visibility:hidden: 修改元素只会造成本元素的重绘,性能消耗较少读屏器读取visibility: hidden元素内容 opacity: 0 : 修改元素会造成重绘,性能消耗较少

      联系:它们都能让元素不可见

      补充:株连性 如果祖先元素遭遇某祸害,则其子孙孙无一例外也要遭殃,比如: opacity:0和display:none,若父节点元素应用了opacity:0和display:none,无论其子孙元素如何挣扎都不会再出现在大众视野; 而若父节点元素应用visibility:hidden,子孙元素应用visibility:visible,那么其就会毫无意外的显现出来。

    总结:

    1. display: none (不占空间,不能点击)(场景,显示出原来这里不存在的结构)
    2. visibility: hidden(占据空间,不能点击)(场景:显示不会导致页面结构发生变动,不会撑开)
    3. opacity: 0(占据空间,可以点击)(场景:可以跟transition搭配)

    总结:

    • display: none;
    1. DOM 结构:浏览器不会渲染 display 属性为 none 的元素,不占据空间;
    2. 事件监听:无法进行 DOM 事件监听;
    3. 性能:动态改变此属性时会引起重排,性能较差;
    4. 继承:不会被子元素继承,毕竟子类也不会被渲染;
    5. transition:transition 不支持 display
    • visibility: hidden;
    1. DOM 结构:元素被隐藏,但是会被渲染不会消失,占据空间;
    2. 事件监听:无法进行 DOM 事件监听;
    3. 性 能:动态改变此属性时会引起重绘,性能较高;
    4. 继 承:会被子元素继承,子元素可以通过设置 visibility: visible; 来取消隐藏;
    5. transition:transition 不支持 display
    • opacity: 0;
    1. DOM 结构:透明度为 100%,元素隐藏,占据空间;
    2. 事件监听:可以进行 DOM 事件监听;
    3. 性 能:提升为合成层,不会触发重绘,性能较高;
    4. 继 承:会被子元素继承,且,子元素并不能通过 opacity: 1 来取消隐藏;
    5. transition:transition 不支持 opacity
    今天你学习了吗!!!
  • 相关阅读:
    存储过程的语法
    C#之理解接口的作用
    获取gridview模板列里面的控件的ID
    asp.net asp:Repeater嵌套绑定方法(2)
    asp.net asp:Repeater嵌套绑定方法(1)
    listview 绑定hashtable 以及值的显示
    mark
    程序员的路该怎么样继续走下去?
    多条件查询以及分页存储过程(倒叙和顺序查询)
    发生ActionScript 错误:[RPC Fault faultString="发送失败" faultCode="Client.Error.MessageSend" faultDetail="Channel.Connect.Failed
  • 原文地址:https://www.cnblogs.com/nayek/p/11813741.html
Copyright © 2020-2023  润新知