CSS元素显示类型

display 属性是 CSS 中最重要的属性之一,主要用来控制元素的布局,通过 display 属性您可以设置元素是否显示以及如何显示。

根据元素类型的不同,每个元素都有一个默认的 display 属性值,例如<div>默认的 display 属性值为
block(块级元素),而<span>默认的 display 属性值为 inline(行内元素),您也可以手动将元素的 display
属性转换为其它值。display 属性的可选值如下:

描述
none隐藏元素
block将元素设置为块级元素
inline将元素设置为内联元素
list-item将元素设置为列表项目
inline-block将元素设置为行内块元素
table将元素设置为块元素级的表格(类似<table>
inline-table将元素设置为内联元素级的表格(类似<table>
table-caption将元素设置为表格的标题(类似<caption>
table-cell将元素设置为表格的单元格(类似<td><th>
table-row将元素设置为表格的行(类似<tr>
table-row-group将元素设置为表格的内容部分(类似 <tbody>
table-column将元素设置为表格的列(类似<col>
table-column-group将元素设置为表格中一个或多个列的分组(类似<colgroup>
table-header-group将元素设置为表格的头部(类似<thead>
table-footer-group将元素设置为表格的脚(类似<tfoot>
boxCSS3 中新增的属性值,表示将对象设置为弹性伸缩盒(伸缩盒的最老版本)
inline-boxCSS3 中新增的属性值,表示将对象设置为内联元素级的弹性伸缩盒(伸缩盒的最老版本)
flexboxCSS3 中新增的属性值,表示将对象设置为弹性伸缩盒(伸缩盒的过渡版本)
inline-flexboxCSS3 中新增的属性值,表示将对象设置为内联元素级的弹性伸缩盒(伸缩盒的过渡版本)
flexCSS3 中新增的属性值,表示将对象设置为弹性伸缩盒(伸缩盒的最新版本)
inline-flexCSS3 中新增的属性值,表示将对象设置为内联元素级的弹性伸缩盒(伸缩盒的最新版本)
run-in根据上下文来决定将元素设置为块级元素或内联元素
inherit从父元素继承 display 属性的值

伸缩盒子(弹性盒子)是 CSS3
中一种新的布局模式,引入伸缩盒子的目的是提供一种更加有效的方式来对页面中的元素进行排列、对齐和分配空间,当页面需要适应不同的屏幕大小以及设备类型时这种布局方式能够确保元素拥有恰当尺寸和位置。

下面通过几个常用的属性值来介绍以下 display 属性的使用:

display: none

display 的属性值 none 可以用来隐藏元素,与前面我们介绍《CSS
visibility
》时提到的visibility: hidden;功能相似,不同的是display: none;在隐藏元素的同时,它还会将元素所占的位置一并隐藏。display: none; 通常会与 JavaScript
结合使用来隐藏或显示某个元素,下面通过一个示例来演示一下:

<!DOCTYPE html>

<html>

<head>

    <style>

        div {

            width: 350px;

            height: 100px;

            background-color: #AAA;

        }

    </style>

</head>

<body>

    <div id="box"> </div>

    <button onclick="change_box(this)">隐藏</button>

    <script>

        function change_box(obj){

            var box = document.getElementById('box');

            if(box.style.display == 'none'){

                box.style.display = "";

                obj.innerHTML = "隐藏";

            }else{

                box.style.display = "none";

                obj.innerHTML = "显示";

            }

        }

    </script>

</body>

</html>

运行上面的代码,在页面中点击“显示”或“隐藏”按钮即可对页面中指定的元素执行显示或隐藏操作,如下图所示:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传
图:display: none; 属性演示

display: block

display 属性的属性值 block 可以将元素强制转换为块级元素,示例代码如下:

<!DOCTYPE html>

<html>

<head>

    <style>

        a{

            display: block;

            width: 150px;

            height: 50px;

            background-color: #ACC;

            line-height: 50px;

            text-align: center;

            text-decoration: none;

        }

    </style>

</head>

<body>

    <a href="">这是一个链接</a>

</body>

</html>

运行结果如下图所示:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传
图:display: block; 属性演示

display: inline

display 属性的属性值 inline 可以将元素强制转换为行内元素,让元素拥有行内元素的特性,例如可以与其他行内元素共享一行等,示例代码如下:

<!DOCTYPE html>

<html>

<head>

    <style>

        div {

            width: 50px;

            height: 50px;

            background-color: #ACC;

            border: 1px solid black;

        }

        .inline {

            display: inline;

        }

    </style>

</head>

<body>

    <div></div>

    <div></div>

    <div class="inline">display: inline;</div>

    <div class="inline">display: inline;</div>

</body>

</html>

运行结果如下图所示:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传
图:display: inline; 属性演示

display: inline-block

display 属性的属性值 inline-block 可以将元素强制转换为行内块元素,inline-block 既具有 block
能够设置宽高的特性又具有 inline 不独占一行的特性,示例代码如下:

<!DOCTYPE html>

<html>

<head>

    <style>

        div {

            width: 130px;

            height: 50px;

            background-color: #ACC;

            border: 1px solid black;

        }

        .inline-block {

            display: inline-block;

            text-align: center;

            margin-top: 10px;

        }

    </style>

</head>

<body>

    <div></div>

    <div></div>

    <div class="inline-block">display: inline-block;</div>

    <div class="inline-block">display: inline-block;</div>

</body>

</html>

运行结果如下图所示:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传
图:display: inline-block; 属性演示

原文地址CSS元素显示类型

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值