如何使 HTML <dt> 和 <dd> 元素保持在同一行


HTML 描述列表 或定义列表 <dl> 以字典格式显示元素。<dt><dd> 标签在 HTML 中与 <dl> 标签一起使用来定义术语或给出其描述。在一个父定义列表中,<dd> 元素用于将定义描述与包含在 <dt> 标签中的同级定义术语配对。

示例

让我们看看一个简单的描述列表的示例。

<!DOCTYPE html>
<html>
<head>
<title>Example of a description list</title>
</head>
<body>
<p style="font-size:20px">A data definition list</p>
<dl>  
  <dt>Data term 1</dt>  
  <dd>Data definition 1</dd>  
  <dt>Data term 2</dt>  
  <dd>Data definition 2</dd> 
  <dt>Data term 3</dt>  
  <dd>Data definition 3</dd>  
  <dt>Data term 4</dt>  
  <dd>Data definition 4</dd>
</dl>  
</body>
</html>

默认情况下,<dt> 和 <dd> 元素不会显示在同一行。在本段代码中,我们将讨论一些使用某些 CSS 属性的方法,以强制 <dt> 及其对应的 <dd> 元素保持在同一行。

使用 CSS float 属性

float 属性用于内容定位和格式化。它用于将元素定位到其容器的左侧和右侧,以及允许文本和内联元素环绕它。它定义了页面的内容流。

如果一个元素从内容的正常流中移除,则其余元素将包含在流中。绝对定位的元素会忽略此属性。它可以写在 CSS 文件中,也可以直接指定在元素的样式中。

语法

以下是语法:

float: none|left|right;

其中,

  • none: 指定元素不浮动。这是默认设置。

  • left: 指定元素浮动在容器的左侧。

  • right: 指定元素浮动在容器的右侧。

示例

在这个示例中,我们使用 CSS float 属性的 left 值,并使用百分比作为 width 属性,以使 <dt> 和 <dd> 并排显示。

<!DOCTYPE html>
<html>
  <head>
    <title>How to Make HTML <dt> and <dd> Elements Stay on the Same Line</title>
    <style>
      dl {
        background:lightpink;
        width: 100%;
        overflow: hidden;
      }
      dt {
        background:lavenderblush;
        float: left;
        width: 50%;

      }
      dd {
        background:lavenderblush;
        float: left;
        width: 50%;
        margin:0;
      }
    </style>
  </head>
  <body>
    <dl>
      <dt>Data term 1</dt>
      <dd>
        This line contains the definition for the data term 1.
      </dd>
      <dt>Data term 2</dt>
      <dd>
        This line contains the definition for the data term 2.
      </dd>
    </dl>
  </body>
</html>

使用 ::after 伪元素

在 CSS 中,::after 创建一个伪元素,它是所选元素的最后一个子元素。它是一个生成的 content 元素,它可以用于插入任何类型的 content,例如字符、文本字符串和图像。content 属性确定其值。它默认情况下为内联,并且像所有其他 content 一样,它可以被动画化、定位和浮动。

示例

在下面的示例中,我们使用 clear 属性与 float 属性一起使用,并在 <dt> 元素上添加 ::after 伪元素。

<!DOCTYPE html>
<html>
  <head>
    <title>How to Make HTML <dt> and <dd> Elements Stay on the Same Line</title>
    <style>
      dl {
        width:300px;
        border: 2px solid saddlebrown;
        padding:10px;
      }
      dt {
        float: left;
        clear: left;
        width: 80px;
        text-align: left;
      }
      dt::after {
        content: " - ";
      }
    </style>
  </head>
  <body>
    <dl>
      <dt>Term 1</dt>
      <dd>Definition 1</dd>
      <dt>Term 2</dt>
      <dd>Definition 2</dd>
    </dl>
  </body>
</html>

使用 Flexbox

Flexbox 是一种一维布局方法,允许用户将项目排列成行或列。它擅长获取各种大小的项目集合,并为这些项目返回最佳布局。Flexbox 允许您提供灵活的边界来暗示 content 可能如何显示,而不是为浏览器提供需要遵循的严格维度。

Flex 容器属性为

  • flex-direction: 定义容器希望如何堆叠 Flex 项目的方向。

  • flex-wrap: 指定是否应换行 Flex 项目。

  • flex-flow: 它是上述两个属性的简写属性。

  • justify-content: 用于对齐 Flex 项目。

  • align-items: 用于对齐 Flex 项目。

  • align-content: 用于对齐 Flex 行。

Flex 项目属性为

  • order: 指定 Flex 项目的顺序。

  • flex-grow: 指定 Flex 项目相对于其他 Flex 项目的增长程度。

  • flex-shrink: 指定 Flex 项目相对于其他 Flex 项目的收缩程度。

  • flex-basis: 指定 Flex 项目的默认长度。

  • flex: 它是上述三个属性的简写属性。

  • align-self: 指定所选项目在弹性容器内的对齐方式。

示例

在以下示例中,我们为 <dl> 元素添加了带有“row wrap”值的 flex-flow 属性。我们还为 <dt> 和 <dd> 元素指定了 flex-basis 属性,并为 <dd> 元素指定了 flex-grow 属性。

<!DOCTYPE html>
<html>
  <head>
    <title>How to Make HTML <dt> and <dd> Elements Stay on the Same Line</title>
    <style>
      dl {
        width:250px;
        display: flex;
        flex-flow: row wrap;
        border: 2px solid purple;
      }
      dt {
        flex-basis: 20%;
        padding: 2px 5px;
        background:indigo ;
        text-align: center;
        color: #fff;
      }
      dd {
        flex-basis: 70%;
        flex-grow: 1;
        margin: 0;
        text-align: center;
        padding: 2px 5px;
        border-bottom: 1px solid black;
      }
    </style>
  </head>
  <body>
    <dl>
      <dt>Term 1</dt>
      <dd>Definition 1</dd>
      <dt>Term 2</dt>
      <dd>Definition 2</dd>
      <dt>Term 3</dt>
      <dd>Definition 3</dd>
    </dl>
  </body>
</html>

更新于: 2023年9月11日

955 次浏览

开启你的 职业生涯

完成课程获得认证

开始学习
广告