即使是品牌塑造,也可以自适应。 您可以根据用户的偏好调整网站的呈现方式。 不过,我们先来介绍如何扩展您网站的品牌信息,以包含浏览器本身。
自定义浏览器界面
某些浏览器允许您根据网站的调色板推荐主题颜色。
浏览器界面会根据您建议的颜色进行调整。在网页的 head
中名为 theme-color
的 meta
元素中添加颜色。
<meta name="theme-color" content="#00D494">
您可以使用 JavaScript 更新 theme-color
的值。但请慎重使用这一功能。
如果用户浏览器的配色方案变化过于频繁,可能会让用户感到无所适从。
想一想如何巧妙地调整主题颜色。如果更改过于突兀,则会让用户感到厌烦。
您还可以在 Web 应用清单文件中指定主题颜色。这是一个包含网站元数据的 JSON 文件。
从文档的 head
链接到清单文件。使用 rel
值为 manifest
的 link
元素。
<link rel="manifest" href="/manifest.json">
在清单文件中,使用键值对列出元数据。
{
"short_name": "Clearleft",
"name": "Clearleft design agency",
"start_url": "/",
"background_color": "#00D494",
"theme_color": "#00D494",
"display": "standalone"
}
如果访问者决定将您的网站添加到其主屏幕,浏览器将使用您的清单文件中的信息来显示相应的快捷方式。
提供深色模式
许多操作系统允许用户指定偏好的浅色或深色调色板,这是根据用户的主题偏好优化网站的绝佳做法。您可以在名为 prefers-color-scheme
的媒体功能中访问此偏好设置。
@media (prefers-color-scheme: dark) {
// Styles for a dark theme.
}
使用 meta
元素内的 prefers-color-scheme
媒体功能指定主题颜色。
<meta name="theme-color" content="#ffffff" media="(prefers-color-scheme: light)">
<meta name="theme-color" content="#000000" media="(prefers-color-scheme: dark)">
您还可以在 SVG 中使用 prefers-color-scheme
媒体功能。
如果您使用 SVG 文件制作网站图标,可以针对深色模式调整网站图标。
Thomas Steiner 写道,适用于深色模式图标的 SVG 网站图标中的 prefers-color-scheme
。
使用自定义属性设置主题
如果您在 CSS 中的多个位置使用相同的颜色值,那么在 prefers-color-scheme
媒体查询中重复所有选择器可能会非常繁琐。
body {
background-color: white;
color: black;
}
input {
background-color: white;
color: black;
border-color: black;
}
button {
background-color: black;
color: white;
}
@media (prefers-color-scheme: dark) {
body {
background-color: black;
color: white;
}
input {
background-color: black;
color: white;
border-color: white;
}
button {
background-color: white;
color: black;
}
}
使用 CSS 自定义属性存储您的颜色值。 自定义属性的作用类似于编程语言中的变量。您可以在不更新变量名称的情况下更新变量的值。
如果您在 prefers-color-scheme
媒体查询中更新自定义属性的值,则无需两次编写所有选择器。
html {
--page-color: white;
--ink-color: black;
}
@media (prefers-color-scheme: dark) {
html {
--page-color: black;
--ink-color: white;
}
}
body {
background-color: var(--page-color);
color: var(--ink-color);
}
input {
background-color: var(--page-color);
color: var(--ink-color);
border-color: var(--ink-color);
}
button {
background-color: var(--ink-color);
color: var(--page-color);
}
有关使用自定义属性的主题设置的更高级示例,请参阅构建配色方案。
图像
如果您在 HTML 中使用 SVG,还可以在 HTML 中应用自定义属性。
svg {
stroke: var(--ink-color);
fill: var(--page-color);
}
现在,您的图标会随页面上的其他元素一起改变颜色。
如果您想降低摄影图片在深色模式下显示的亮度,可以在 CSS 中应用滤镜。
@media (prefers-color-scheme: dark) {
img {
filter: brightness(.8) contrast(1.2);
}
}
对于某些图片,您可能希望在深色模式下完全更换这些图片。
例如,您可能希望显示配色方案较深的地图。在 prefers-color-scheme
媒体查询中使用包含 <source>
元素的 <picture>
元素。
<picture>
<source srcset="darkimage.png" media="(prefers-color-scheme: dark)">
<img src="lightimage.png" alt="A description of the image.">
</picture>
表单
浏览器会为表单字段提供默认调色板。 让浏览器知道您的网站同时提供深色模式和浅色模式。 这样,浏览器就可以为表单提供适当的默认样式。
将以下内容添加到您的 CSS 中:
html {
color-scheme: light;
}
@media (prefers-color-scheme: dark) {
html {
color-scheme: dark;
}
}
您也可以使用 HTML。将以下内容添加到您的文档的 head
中:
<meta name="supported-color-schemes" content="light dark">
使用 CSS 中的 accent-color
属性设置复选框、单选按钮和其他一些表单字段的样式。
html {
accent-color: red;
}
深色主题通常具有柔和的品牌颜色。您可以更新深色模式的 accent-color
值。
html {
accent-color: red;
}
@media (prefers-color-scheme: dark) {
html {
accent-color: pink;
}
}
这时,就应该使用自定义属性,这样您便可以将所有颜色声明保存在一个位置。
html {
color-scheme: light;
--page-color: white;
--ink-color: black;
--highlight-color: red;
}
@media (prefers-color-scheme: dark) {
html {
color-scheme: dark;
--page-color: black;
--ink-color: white;
--highlight-color: pink;
}
}
html {
accent-color: var(--highlight-color);
}
body {
background-color: var(--page-color);
color: var(--ink-color);
}
提供深色模式只是调整网站以适应用户的偏好的一个示例。 接下来,您将了解如何使网站适应各种无障碍注意事项。
检查您的掌握程度
测试您对主题设置知识的掌握情况
如需提供会影响网页外浏览器的主题颜色,请使用以下代码:
<meta>
标记时。manifest.json
,并且可以包含用于指定主题颜色的字段,以便对从移动设备主屏幕打开应用进行色调调节。<meta>
标记<head>
标记中发现该主题颜色,从而避免不必要的颜色闪烁。要连接到用户针对浅色或深色主题的系统偏好设置,请使用:
(prefers-color-scheme)
媒体查询因此,您支持深色主题,但所有表单输入仍采用浅色主题。该怎么做?
html { color-scheme: light dark; }
添加到您的 CSS 中。<meta name="supported-color-schemes" content="light dark">
添加到 HTML <head>
标记中。