CSS-根


CSS 伪类:root旨在选择文档层次结构中的根元素。当应用于 HTML 时,:root特别指向 <html> 元素,其Behave与“html”选择器类似。尽管如此,值得强调的是,与“html”相比,:root具有更大的特异性。该选择器包括所有 HTML 元素或标签。

在 CSS 中声明全局变量时,使用:root会很有优势。

句法

:root {
  // css declarations or property
  --main-color: blue;
  --secondary-color: white;
}

例子

这是显示:root用法的示例-

<html>
<head>
<style>
     /* Define global variables */
    :root {
      --main-color: blue;
      --secondary-color: white;
    }
    body {
      background-color: var(--main-color);
    }
    h1 {
      color: var(--secondary-color);
    }
</style>
</head>
<body>
  <h1>Welcome to CSS Root Example</h1>
  <p>This is an example of using CSS root to define and use custom CSS variables.</p>
</body>
</html>

例子

这是另一个示例,演示了如何使用:root选择器来设置不同元素的样式 -

<html>
<head>
<title>:root Example</title>
<style>
   :root {
      --primary-color: #007bff;
      --secondary-color: #6c757d;
      --background-color: #fcfc90;
   }

   body {
      background-color: var(--background-color);
      color: var(--secondary-color);
      font-family: Arial, sans-serif;
   }
   h1 {
      color: var(--primary-color);
   }
   p {
      margin-bottom: 1rem;
   }

   .container {
      max-width: 800px;
      margin: 0 auto;
      padding: 2rem;
      background-color: LightYellow;
      box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
   }
   .button {
      display: inline-block;
      padding: 0.5rem 1rem;
      background-color: var(--primary-color);
      color: white;
      text-decoration: none;
      border-radius: 4px;
      }
</style>
</head>
<body>
   <div class="container">
      <h1>:root Example</h1>
      <p>This is an example of using the <code>:root</code> selector to define global CSS variables.</p>
      <p>The primary color is set to <span style="color: var(--primary-color);">var(--primary-color)</span>.</p>
      <p>The secondary color is set to <span style="color: var(--secondary-color);">var(--secondary-color)</span>.</p>
      <p>The background color is set to <span style="background-color: var(--background-color); color: red;">var(--background-color)</span>.</p>
      <a href="#" class="button">Demo</a>
   </div>
</body>
</html>