主题
Ionic 提供了多个全局变量,这些变量在组件中广泛使用,用于改变整个应用程序的默认主题。应用颜色 可用于改变大多数 Ionic 组件的外观,而 阶梯颜色 则在部分 Ionic 组件中作为颜色变体使用。
应用颜色
应用颜色在 Ionic 的多个位置被使用。它们便于轻松创建深色调色板或与品牌相匹配的主题。
需要注意的是,背景和文本颜色变量还需要一个以 rgb 格式 设置的 rgb 变量。请参阅 透明度问题 了解为何还需要 rgb 属性的解释。
| 名称 | 描述 |
|---|---|
--ion-background-color | 整个应用的背景色 |
--ion-background-color-rgb | 整个应用的背景色,rgb 格式 |
--ion-text-color | 整个应用的文本颜色 |
--ion-text-color-rgb | 整个应用的文本颜色,rgb 格式 |
--ion-backdrop-color | Backdrop 组件的颜色 |
--ion-backdrop-opacity | Backdrop 组件的不透明度 |
--ion-overlay-background-color | 覆盖层的背景颜色 |
--ion-border-color | 边框颜色 |
--ion-box-shadow-color | 盒阴影颜色 |
--ion-tab-bar-background | Tab 栏的背景 |
--ion-tab-bar-background-focused | 获得焦点时 Tab 栏的背景 |
--ion-tab-bar-border-color | Tab 栏的边框颜色 |
--ion-tab-bar-color | Tab 栏的颜色 |
--ion-tab-bar-color-selected | 被选中的 Tab 按钮的颜色 |
--ion-toolbar-background | Toolbar 的背景 |
--ion-toolbar-border-color | Toolbar 的边框颜色 |
--ion-toolbar-color | Toolbar 中组件的颜色 |
--ion-toolbar-segment-color | Toolbar 中 Segment 按钮的颜色 |
--ion-toolbar-segment-color-checked | Toolbar 中被选中的 Segment 按钮的颜色 |
--ion-toolbar-segment-background | Toolbar 中 Segment 按钮的背景 |
--ion-toolbar-segment-background-checked | Toolbar 中被选中的 Segment 按钮的背景 |
--ion-toolbar-segment-indicator-color | Toolbar 中 Segment 按钮指示器的颜色 |
--ion-item-background | Item 的背景 |
--ion-item-border-color | Item 的边框颜色 |
--ion-item-color | Item 中组件的颜色 |
--ion-placeholder-color | Input 中占位符的颜色 |
阶梯颜色
在探索了多种自定义 Ionic 主题的方法后,我们发现不能只使用单一背景色或文本色。为了在设计中体现重要性和层次感,我们需要使用不同深浅的背景色和文本色。为了适应这种模式,我们创建了阶梯颜色。
虽然更新背景 (--ion-background-color) 和文本 (--ion-text-color) 变量会改变大多数组件的外观,但对于某些 Ionic 组件来说,这可能会显得不协调或异常。这在应用深色调色板时会更明显。
在某些组件中,我们使用比背景色略深或比文本色略浅的颜色。例如,项目标题文本可能需要使用 #404040,这比我们的默认文本色浅几个色阶。同时,加载组件的背景色比白色略深,使用 #f2f2f2。我们使用阶梯颜色来定义这些细微的差异。在更新应用程序的背景色或文本颜色时,更新阶梯颜色非常重要。
Ionic 为文本和背景颜色提供了独立的阶梯颜色,以便它们可以单独更新。这对于同时使用文本和背景阶梯颜色的组件非常有用,并使我们能够有效实现 高对比度调色板。
默认情况下,Ionic 的文本阶梯颜色以默认文本颜色值 #000000 开始,并按照递增的百分比与背景颜色值 #ffffff 混合。Ionic 的背景阶梯颜色以默认背景颜色值 #ffffff 开始,并按照递增的百分比与文本颜色值 #000000 混合。完整的阶梯颜色列表如下方生成器所示。
阶梯颜色生成器
为您的应用创建自定义背景和文本颜色主题。更新下方的背景或文本颜色的十六进制值,然后将生成的代码直接复制并粘贴到您的 Ionic 项目中。
Background
Text
:root {
--ion-background-color: #ffffff;
--ion-background-color-rgb: 255,255,255;
--ion-text-color: #000000;
--ion-text-color-rgb: 0,0,0;
--ion-text-color-step-50: #0d0d0d;
--ion-text-color-step-100: #1a1a1a;
--ion-text-color-step-150: #262626;
--ion-text-color-step-200: #333333;
--ion-text-color-step-250: #404040;
--ion-text-color-step-300: #4d4d4d;
--ion-text-color-step-350: #595959;
--ion-text-color-step-400: #666666;
--ion-text-color-step-450: #737373;
--ion-text-color-step-500: #808080;
--ion-text-color-step-550: #8c8c8c;
--ion-text-color-step-600: #999999;
--ion-text-color-step-650: #a6a6a6;
--ion-text-color-step-700: #b3b3b3;
--ion-text-color-step-750: #bfbfbf;
--ion-text-color-step-800: #cccccc;
--ion-text-color-step-850: #d9d9d9;
--ion-text-color-step-900: #e6e6e6;
--ion-text-color-step-950: #f2f2f2;
--ion-background-color-step-50: #f2f2f2;
--ion-background-color-step-100: #e6e6e6;
--ion-background-color-step-150: #d9d9d9;
--ion-background-color-step-200: #cccccc;
--ion-background-color-step-250: #bfbfbf;
--ion-background-color-step-300: #b3b3b3;
--ion-background-color-step-350: #a6a6a6;
--ion-background-color-step-400: #999999;
--ion-background-color-step-450: #8c8c8c;
--ion-background-color-step-500: #808080;
--ion-background-color-step-550: #737373;
--ion-background-color-step-600: #666666;
--ion-background-color-step-650: #595959;
--ion-background-color-step-700: #4d4d4d;
--ion-background-color-step-750: #404040;
--ion-background-color-step-800: #333333;
--ion-background-color-step-850: #262626;
--ion-background-color-step-900: #191919;
--ion-background-color-step-950: #0d0d0d;
}