ConfigProvider 全局配置
介绍
用于全局配置 Wot 组件,提供深色模式、主题定制等能力。
深色模式
将 ConfigProvider 组件的 theme 属性设置为 dark,可以开启深色模式。
深色模式会全局生效,使页面上的所有 Wot 组件变为深色风格。
vue
<wd-config-provider theme="dark">...</wd-config-provider>TIP
值得注意的是,开启 Wot 的深色模式只会影响 Wot 组件的 UI,并不会影响全局的文字颜色或背景颜色,你可以参考以下 CSS 来设置一些全局样式:
css
.wot-theme-dark body {
color: #f5f5f5;
background-color: black;
}动态切换
通过动态设置 theme 属性,可以在浅色风格和深色风格之间进行切换。
vue
<wd-config-provider :theme="theme">...</wd-config-provider>ts
export default {
setup() {
const theme = ref('light')
setTimeout(() => {
theme.value = 'dark'
}, 1000)
return { theme }
}
}定制主题
Wot 组件通过丰富的 CSS 变量 来组织样式,通过覆盖这些 CSS 变量,可以实现定制主题、动态切换主题等效果。
示例
这些变量的默认值被定义在 page 节点上,如果要转 H5,默认值被定义在 :root 节点上
css
:root,
page {
--wot-color-success: red;
--wot-color-warning: yellow;
}通过 CSS 覆盖
你可以直接在代码中覆盖这些 CSS 变量,Button 组件的样式会随之发生改变:
css
/* 添加这段样式后,默认 Button 底色会变成绿色 */
:root,
page {
--wot-button-normal-bg: green;
}通过 ConfigProvider 覆盖
ConfigProvider 组件提供了覆盖 CSS 变量的能力,你需要在根节点包裹一个 ConfigProvider 组件,并通过 theme-vars 属性来配置一些主题变量
html
<wd-config-provider :theme-vars="themeVars">
<div style="margin: 16px">
<wd-button round block type="primary">提交</wd-button>
</div>
</wd-config-provider>ts
import { ref, reactive } from 'vue'
export default {
setup() {
// themeVars 内的值会被转换成对应 CSS 变量
// 比如 buttonPrimaryBg 会转换成 `--wot-button-primary-bg-color`
const themeVars = reactive({
buttonPrimaryBgColor: '#07c160',
buttonPrimaryColor: '#07c160'
})
return {
themeVars
}
}
}在 TypeScript 中使用
在 TypeScript 中定义 themeVars 时,建议使用 wot-design-uni 提供的 ConfigProviderThemeVars 类型,可以提供完善的类型提示:
ts
import type { ConfigProviderThemeVars } from 'wot-design-uni';
const themeVars: ConfigProviderThemeVars = {
colorTheme: 'red'
}TIP
注意:ConfigProvider 仅影响它的子组件的样式,不影响全局 root 节点。
Attributes
| 参数 | 说明 | 类型 | 可选值 | 默认值 | 最低版本 |
|---|---|---|---|---|---|
| theme | 主题风格,设置为 dark 来开启深色模式,全局生效 | string | dark/light | - | - |
| theme-vars | 自定义主题变量 | ConfigProviderThemeVars | - | - | - |
