元素隐藏与显示属性及操作方式

2022-10-26 16:25:43 浏览数 (3)

元素的隐藏显示经常会使用,比如二级导航,响应式布局等等。

使用场景:让某元素在屏幕中不可见,如:鼠标:hover之后元素隐藏/显示

常用属性方法:

visibility: hidden;

浏览器对其渲染可是不可见,它在网页中占位置却不可点击,也就是说明元素不可见却仍然占据空间。

代码语言:javascript复制
/* 元素隐藏 */
display:none;
/* 元素显示 */
display:block;

隐藏元素本身,并且在网页中不占位置,在隐藏的方法中,取none值这种方法一般是不可取的!因为display:none是直接不显示,也就是不渲染此元素,如果它所作用的元素排版在页面较前,先渲染,就容易引起回流(reflow)和重绘(repaint),造成难以预知的后果。

代码语言:javascript复制
/* 表示完全不透明*/
opacity:1;
/* 表示完全透明*/
opacity:0;

注意: 会让元素整体变透明,包括里面的内容,如:文字、子元素等…

展示案例(导航的二维码默认隐藏点击显示)

代码语言:javascript复制
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        /* 因为有通栏:占满一行的边框,所以需要有一个通栏:占满一行的盒子 */
      
        .nav {
            height: 40px;
            border-bottom: 1px solid #ccc;
        }
        /* 因为ul中所有的内容都是在网页的宽度固定并且水平居中的盒子内部,所以设置ul为宽度固定并且水平居中的效果(后面项目中所用到的版心) */
      
        ul {
            list-style: none;
            width: 1200px;
            margin: 0 auto;
        }
      
        ul li {
            float: left;
            width: 20%;
            height: 40px;
            border-right: 1px solid #ccc;
            /* 自动内减 */
            box-sizing: border-box;
            text-align: center;
            line-height: 40px;
        }
      
        ul .last {
            border-right: none;
        }
      
        ul li a {
            /* a标签默认是行内元素,宽高由内容撑开,并且无法设置宽高,此时默认情况用户只能点击文字区域才能调整 */
            /* 如果把a标签转换成块级元素,此时可以设置宽高,会让a标签范围更大,用户可以点击调整的区域也越大 */
            display: block;
            /* 宽度不设置块元素会默认占满一行 */
            height: 40px;
            text-decoration: none;
            color: #000;
        }
      
        .nav .app {
            position: relative;
        }
      
        .nav .app .code {
            display: none;
            position: absolute;
            left: 50%;
            transform: translateX(-50%);
            top: 40px;
            border: 1px solid #ccc;
        }
      
        .nav .app:hover .code {
            display: block;
        }
    </style>
</head>
<body>
    <!-- 导航 -->
    <div class="nav">
        <ul>
            <li><a href="#">我要投资</a></li>
            <li><a href="#">平台介绍</a></li>
            <li><a href="#">新手专区</a></li>
            <li><a href="#" class="app">手机微金所<img src="./img/code.jpg" alt="" class="code"></a></li>
            <li class="last"><a href="#">个人中心</a></li>
        </ul>
    </div>
</body>
</html>

0 人点赞