Java教程

使用 10 行 JavaScript 代码实现基于用户操作系统偏好的明暗主题切换

本文主要是介绍使用 10 行 JavaScript 代码实现基于用户操作系统偏好的明暗主题切换,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

引言

在当今的 Web 开发中,为用户提供个性化体验已成为一种标准做法。其中一个流行的趋势就是支持暗模式,因为它不仅有助于节省电池电量,还能减轻长时间使用屏幕带来的视觉疲劳。在这篇文章中,我们将介绍如何使用简单的 JavaScript 代码和 CSS 来根据用户的操作系统偏好自动切换网站的主题,并允许用户手动在明暗模式之间切换。

目标

我想要实现什么? 我试图用这种方法实现两件事。

  1. 我需要允许网站以用户喜欢的方式加载(他们已经在操作系统中选择了主题的部分)
  2. 但我还想允许他们在加载后在暗模式和亮模式之间切换。

因此,我们将有一个网站,可以加载用户期望的主题,然后允许他们在需要时进行更改。

实现步骤

步骤 1: 创建切换按钮

首先,我们需要在 HTML 中添加一个按钮或图标作为切换主题的触发器。

<button class="mode" aria-label="Toggle Theme">
    <img class="lazyload" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC" data-original="./yueliang.png">
</button>

我使用的图片作为按钮,其中包含月亮的 svg 图片。您可以添加按钮或复选框,以便在两个选项之间切换。

步骤 2: 将颜色详细信息作为自定义属性放入 CSS 中

接下来,我们需要在 CSS 中定义主题相关的颜色,并使用 color-scheme 属性来指定配色方案。我们将使用 light-dark() 函数来根据用户的偏好自动选择颜色:

:root {
  color-scheme: light dark;
  --light-bg: ghostwhite;
  --light-color: darkslategray;
  --light-code: tomato;
  --dark-bg: darkslategray;
  --dark-color: ghostwhite;
  --dark-code: gold;
}

body {
  background-color: light-dark(var(--light-bg), var(--dark-bg));
  color: light-dark(var(--light-color), var(--dark-color));
}

code {
  color: light-dark(var(--light-code), var(--dark-code));
}


.light {
  color-scheme: light;
}

.dark {
  color-scheme: dark;
}

好的,所以在:root中你会看到名为的属性color-scheme,这将是我们的游戏规则改变者。 如你所见,它接受值light或dark。我还创建了两个类,.light它们.dark将配色方案的值设置为深色或浅色。

步骤 3: 为代码的各个部分添加颜色

body{
    background-color: light-dark(var(--light-bg), var(--dark-bg));
}
...

现在,每当属性要求颜色时(例如background,color属性),您都可以使用名为的函数light-dark()【MDN官方文档 】 此函数采用两个值,第一个值在color-scheme设置为时使用,第二个值在设置为暗light时使用color-scheme

步骤 4: 使用 JavaScript 在明暗模式间切换

最后,我们需要编写 JavaScript 代码来监听按钮点击事件,并根据用户的系统偏好或当前状态切换主题:

const modeButton = document.querySelector('.mode');

modeButton.addEventListener('click', function () {
  const theme = document.documentElement.style.colorScheme;
  
  if (theme === null) {
    
    if (window.matchMedia('(prefers-color-scheme: dark)').matches) {
      
      document.documentElement.style.colorScheme = 'light';
    } else {
      
      document.documentElement.style.colorScheme = 'dark';
    }
  } else {
    
    document.documentElement.style.colorScheme = (theme === 'light') ? 'dark' : 'light';
  }
});

这里,document.documentElement.style.colorScheme其实是指:rootCSS中的元素。 正如我们在上一步中已经实现以用户首选模式打开网站一样,当单击切换按钮时,它会执行以下工作。

它检查配色方案是否有任何值,如果没有,则网站处于用户首选模式,我们需要确定它是暗还是亮来更改模式。 它用于window.matchMedia("(prefers-color-scheme:dark)").matches查找它是否处于暗模式,如果处于暗模式,我们将配色方案更改为light,如果不是,我们将其更改为dark。 下次他们点击按钮时,我们已经为配色方案设置了值,因此我们只需在深色或浅色之间切换。

实现效果

结论

通过以上步骤,我们成功实现了根据用户操作系统偏好自动加载明暗主题,并提供了一个简单的按钮让用户可以自由切换主题。这种方法既简单又高效,只需要少量的代码即可实现。如果你正在寻找一种轻量级的方式来为你的网站添加主题切换功能,那么这种方法将是一个不错的选择。

这篇关于使用 10 行 JavaScript 代码实现基于用户操作系统偏好的明暗主题切换的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!