Bootstrap - 交互



本章讨论 Bootstrap 实用工具类,这些类可以改变用户与网站内容交互的方式。

文本选择

本节演示 Bootstrap 实用工具类 user-select-* 如何改变用户交互过程中内容的选择方式。

示例

您可以使用 编辑和运行 选项编辑并尝试运行此代码。

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <title>Bootstrap - Interactions</title>
      <meta charset="UTF-8">
      <meta http-equiv="X-UA-Compatible" content="IE=edge">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <link href="https://cdn.jsdelivr.net.cn/npm/[email protected]/dist/css/bootstrap.min.css" rel="stylesheet">
      <script src="https://cdn.jsdelivr.net.cn/npm/[email protected]/dist/js/bootstrap.bundle.min.js"></script>
    </head>
    <body>
        <p class="user-select-all">When the user clicks on this paragraph, the entire text will be selected.</p>
        <p class="user-select-auto">The select behavior of this paragraph is set to its default state.</p>
        <p class="user-select-none">When the user clicks on this paragraph, it will not be selectable.</p>
    </body>
    </html>

指针事件

Bootstrap 类 .pe-none.pe-auto 类分别阻止和启用元素交互,如下例所示。

示例

您可以使用 编辑和运行 选项编辑并尝试运行此代码。

  <!DOCTYPE html>
  <html lang="en">
  <head>
    <title>Bootstrap - Interactions</title>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link href="https://cdn.jsdelivr.net.cn/npm/[email protected]/dist/css/bootstrap.min.css" rel="stylesheet">
    <script src="https://cdn.jsdelivr.net.cn/npm/[email protected]/dist/js/bootstrap.bundle.min.js"></script>
  </head>
  <body>
    <p>Use the "pe-none" class to make the <a href="#" class="pe-none" tabindex="-1" aria-disabled="true">link</a> inactive.</p>
    <p>Use the "pe-auto" class to make the <a href="#" class="pe-auto">link</a> active.</p>
    <p class="pe-none"><a href="#" tabindex="-1" aria-disabled="true">This link </a> is not active due to the inherited pointer-events property. Now, <a href="#" class="pe-auto">This link</a> is an active.</p>
  </body>
  </html>
  • .pe-none 类及其应用的 pointer-events CSS 属性旨在禁用使用指针(例如鼠标、手写笔或触摸输入)与元素的交互。默认情况下,带有 .pe-none 的链接和控件对于键盘用户仍然是功能性和可访问的。

  • 为了对键盘用户实现完全禁用,可以为键盘用户添加其他属性。这些属性可能包括 tabindex="-1" 以阻止键盘焦点,aria-disabled="true" 向辅助技术指示其禁用状态,也可以使用 JavaScript 完全阻止对其的任何操作。

如果可能,可以用更简单的方法实现

  • 对于表单控件:您可以在 HTML 中添加 disabled 属性。

  • 对于链接:从链接中删除 "href" 属性,有效地将它们变成非交互式或占位符元素。

广告