首页 > 其他分享 >如何使用CSS变量 - 通过代码示例解释

如何使用CSS变量 - 通过代码示例解释

时间:2024-04-05 15:47:31浏览次数:34  
标签:变量 示例 -- primary React 使用 CSS

如果你正在构建网站或Web应用程序,你应该已经知道代码重复被认为是一种不良实践。

这就是为什么你应该学习如何使用CSS变量来减少你编写的CSS代码量并将你的样式带到一个新的水平。

最成功的Web应用程序拥有令人惊叹的设计。不幸的是,为了达到预期的效果,Web开发人员需要准备大量的样式。这迫使我们在许多不同的元素中重复值,比如颜色。

幸运的是,现代样式表支持CSS变量,这使您可以减少代码库中的重复。你不需要像CSS模块、Less或SASS这样的外部工具来利用它。

在这个全面的指南中,我将向您展示如何有效地使用CSS变量,涵盖从纯HTML和CSS的基本示例到更高级的框架,如React和Next.js。

(本文内容参考:java567.com)

先决条件

本指南专为初学者而设计,因此您不需要任何特殊知识来从中受益。

我在React和Next.js中包含了一些示例,它们专为初学者React开发人员而设计。只有这些示例需要基本的React知识来理解。如果你不使用React,可以随意跳过它们。

CSS变量是什么?

CSS变量(官方称为CSS自定义属性)允许开发人员在CSS样式表中管理和重复使用值。Web开发人员可以定义可重用的变量,这些变量可以在许多CSS文件中使用,使代码更易于更新。CSS变量使得实现诸如暗黑模式之类的功能变得非常简单。

现代网站需要大量的样式,这导致在许多不同的样式表中重复CSS值。生态系统一直在努力解决这个问题,通过发明诸如SASS、Less和CSS模块等工具,但所有这些工具都有一个缺点 - 最终它们都需要编译成CSS文件。

幸运的是,由于CSS变量,我们可以简化我们的样式表,而不需要复杂的工具和构建过程。

如何创建CSS变量

定义一个CSS变量非常简单。您可以使用--前缀后跟您选择的名称来定义CSS变量,然后使用var()函数为其赋值。

这是如何做的:

:root {
  /* 背景 */
  --primary-background: #faf8ef;
  /* 颜色 */
  --primary-text-color: #776e65;
}

如您所见,我在:root伪类中定义了CSS变量,以使它们在全局范围内可用。

每个变量都以--开头,后跟名称:--primary-background或--primary-text-color。最后,我为这些变量赋了值。

使用这种方法,我只需修改这些变量的值就可以更改网站的颜色。

如何使用CSS变量

现在让我向您展示如何使用CSS变量来为您的网站定义全局背景和文本颜色:

body {
  margin: 0;
  background: var(--primary-background);
  color: var(--primary-text-color);
}

要使用变量,您需要使用var()函数引用它们,并将变量名称作为参数传递。

就是这样!现在您的网站正在使用CSS变量来渲染样式。

注意:var()辅助函数是一个内置的CSS函数,因此您不需要任何库来使用它。

如何在React中使用CSS变量?

许多Web开发人员在React中构建他们的Web应用程序,因此我将向您展示如何在React中获取值并更新CSS变量。许多现代Web应用程序支持暗黑模式,这个功能可能会成为React开发人员的噩梦之一。

接下来,我将向您展示一种仅通过使用CSS变量在React应用程序中添加暗黑模式的简单方法。

如何在React中设置CSS变量的值?

在React中更改CSS变量的值可能会有些棘手,因为React没有提供任何直接与DOM树交互的工具。这就是为什么我们将使用普通JavaScript来读取和设置CSS变量。

以下是您可以在React中设置CSS变量的方法:

import { useEffect } from 'react';

export default function Example() {
  useEffect(() => {
    document.documentElement.style.setProperty('--primary-background', `black`);
    document.documentElement.style.setProperty('--primary-text-color', `white`);
  }, [])

  return <div style={{color: "var(--primary-text-color)"}}>Hello World</div>
};

如您所见,我利用了全局的document变量来进入DOM树并修改样式属性。我使用了setProperty方法,该方法需要两个参数:

  • CSS自定义属性(CSS变量)名称。
  • 变量的值。

注意:无论您是在React中还是在纯JavaScript中工作,您都可以始终调用document.documentElement.style.setProperty来修改CSS变量的值。这是一个JavaScript内置函数。

如何在React中获取CSS变量的值?

有时候您可能需要读取CSS变量的值并将其存储在React中。在这种情况下,我建议利用useState和useEffect钩子。

这是我处理这个问题的方式:

import { useEffect, useState } from 'react';

export default function Example() {
  const [color, setColor] = useState('black');

  useEffect(() => {
    const cssColor = document.documentElement.style.getPropertyValue('--primary-text-color');
    setColor(cssColor);
  }, [])

  return <div style={{color: color}}>Hello World</div>
};

如您所见,我将--primary-text-color变量的值获取到cssColor常量中。在下一行,我使用useState钩子创建的setColor辅助函数更新了组件的状态。使用这种方法,我的CSS变量可以在React组件中轻松使用。

就是这样。现在您可以在您的React应用程序中使用这个变量了。

结论

CSS变量可以在不同类型的网站中使用,而无需使用JavaScript来利用它们。每个人都可以从中受益 - 无论他们在Web开发中的经验水平如何。理解CSS变量可以极大地改善您的样式体验,并使您更加高效。

希望您喜欢这篇文章,别忘了点赞和关注。

(本文内容参考:java567.com)

标签:变量,示例,--,primary,React,使用,CSS
From: https://www.cnblogs.com/web-666/p/18115801

相关文章

  • C# 构造函数 (初始化成员变量的角色)
    构造函数是一种特殊的方法。创建对象时会自动调用它。构造函数不返回值。构造函数的目的是初始化对象的状态。构造函数与类具有相同的名称。构造函数是方法,因此它们也可以重载。构造函数不能被继承。它们按继承顺序被调用。如果我们不为类编写任何构造函数,则C#提供一个......
  • lessc assets/index.less assets/index.css这个命令的作用是什么?
    lesscassets/index.lessassets/index.css这个命令的作用是什么?lesscassets/index.lessassets/index.css这条命令是用来编译Less样式表文件的。具体来说,它的作用如下:lessc:这是Less编译器的命令行工具(lesscstandsforlesscompiler)。它是Less预处理器的一个组成......
  • 配置交换机双归接入IP网络示例(V-STP方式推荐)
    组网需求如图4-23所示,通过配置M-LAG双归接入IP网络可以满足以下要求:当一条接入链路发生故障时,流量可以快速切换到另一条链路,保证可靠性。为了高效利用带宽,两条链路同时处于active状态,可实现使用负载分担的方式转发流量。图4-23 配置M-LAG双归接入IP组网图配置思......
  • 配置M-LAG双归接入普通以太网络示例(根桥方式)
    组网需求如图4-22所示,采用M-LAG方式将主机双归接入普通以太网络。由于用户对于业务的可靠性要求很高,如果主机和接入设备之间做链路聚合只能保证链路级的可靠性,接入设备发生故障时则会导致业务中断。这时用户可以采用跨设备链路聚合技术,正常工作时链路进行负载分担且任何一台......
  • Vite 在一个特殊的 import.meta.env 对象上暴露环境变量。这里有一些在所有情况下都可
    .env文件Vite使用dotenv从你的环境目录中的下列文件加载额外的环境变量: .env#所有情况下都会加载.env.local#所有情况下都会加载,但会被git忽略.env.[mode]#只在指定模式下加载.env.[mode].local#只在指定模式下加载,但会......
  • 给c++小白的教程3:变量
    哈喽大家好,又见面了变量可谓是c++中的一大重点,今天就来给大家讲解一下c++中的变量今天只讲c++自带的变量(不用别的头文件)定义变量用法:数据类型名称=内容输出:cout<<名称;首先是intint指整数变量,范围在-2147483648~2147483647(约21亿)之间用法:inta=23333intb=1234567......
  • 在Linux中,什么是环境变量?如何设置和查看环境变量?
    在Linux系统中,环境变量是一种特殊的变量,它包含了系统或者用户指定的一系列键值对,这些键值对代表了与系统运行环境相关的信息,如路径、配置参数、默认选项等。环境变量对系统和运行在其上的应用程序有着至关重要的影响,它们决定了许多系统行为和应用程序的行为。环境变量的值可在整......
  • 【HTML5+CSS3】HTML知识点+自主练习
    一、W3C标准结构:HTML表现:CSS行为:JavaScript二、HTML常用标签排版标签(标题标签、段落标签、换行标签、分割标签、 文本格式化标签)媒体标签(图片标签、音视频标签)超链接标签(超链接标签)布局标签(div标签、span标签、HTML5新增语义化标签)三、HTML学生示例代码​<!--......
  • Vue3 Diff 之 patchKeyedChildren 动态示例
    在学习全网学习各路大神的关于Vue3Diff算法分析文章的时候,一定离不开关键方法patchKeyedChildren。patchKeyedChildren处理的场景比较多,大致有5个主要过程。如果你希望查看不同测试用例下,patchKeyedChildren具体的内部处理过程,可以尝试一下这个:《Vue3Diff之patchKey......
  • 【WPF应用34】WPF基本控件-Menu的详解与示例
    WPF(WindowsPresentationFoundation)是.NET框架的一个部分,用于构建桌面应用程序的用户界面。在WPF中,菜单(Menu)是一种常用的控件,用于提供一组选项或命令,使用户可以根据自己的需要执行特定的操作。本文将详细介绍WPF中的Menu控件,包括其基本用法、属性和事件。同时,我们将通过一......