mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-06 03:57:59 +08:00
141 lines
14 KiB
JavaScript
141 lines
14 KiB
JavaScript
import{o as a,a as n,y as t}from"./vue-libs.b44bc779.js";const l={class:"van-doc-markdown-body"},e=t(`<h1>ConfigProvider</h1><div class="van-doc-card"><h3 id="intro" tabindex="-1">Intro</h3><p>Used to config the theme and global properties of Vant components.</p></div><div class="van-doc-card"><h3 id="install" tabindex="-1">Install</h3><p>Register component globally via <code>app.use</code>, refer to <a href="#/en-US/advanced-usage#zu-jian-zhu-ce" target="_blank">Component Registration</a> for more registration ways.</p><pre><code class="language-js"><span class="hljs-keyword">import</span> { createApp } <span class="hljs-keyword">from</span> <span class="hljs-string">'vue'</span>;
|
|
<span class="hljs-keyword">import</span> { <span class="hljs-title class_">ConfigProvider</span> } <span class="hljs-keyword">from</span> <span class="hljs-string">'vant'</span>;
|
|
|
|
<span class="hljs-keyword">const</span> app = <span class="hljs-title function_">createApp</span>();
|
|
app.<span class="hljs-title function_">use</span>(<span class="hljs-title class_">ConfigProvider</span>);
|
|
</code></pre></div><h2 id="custom-theme" tabindex="-1">Custom Theme</h2><div class="van-doc-card"><h3 id="intro-1" tabindex="-1">Intro</h3><p>Vant organize component styles through <a href="https://developer.mozilla.org/zh-CN/docs/Web/CSS/Using_CSS_custom_properties" target="_blank">CSS Variables</a>, you can custom themes by overriding these CSS Variables.</p><h4 id="demo" tabindex="-1">Demo</h4><p>Looking at the style of the Button component, you can see that the following variables exist on the <code>.van-button--primary</code> class:</p><pre><code class="language-css"><span class="hljs-selector-class">.van-button--primary</span> {
|
|
<span class="hljs-attribute">color</span>: <span class="hljs-built_in">var</span>(--van-button-primary-color);
|
|
<span class="hljs-attribute">background-color</span>: <span class="hljs-built_in">var</span>(--van-button-primary-background-color);
|
|
}
|
|
</code></pre><p>The default values of these variables are defined on the <code>root</code> node:</p><pre><code class="language-css"><span class="hljs-selector-pseudo">:root</span> {
|
|
<span class="hljs-attr">--van-white</span>: <span class="hljs-number">#fff</span>;
|
|
<span class="hljs-attr">--van-blue</span>: <span class="hljs-number">#1989fa</span>;
|
|
<span class="hljs-attr">--van-button-primary-color</span>: <span class="hljs-built_in">var</span>(--van-white);
|
|
<span class="hljs-attr">--van-button-primary-background-color</span>: <span class="hljs-built_in">var</span>(--van-primary-color);
|
|
}
|
|
</code></pre></div><div class="van-doc-card"><h3 id="custom-css-variables" tabindex="-1">Custom CSS Variables</h3><h4 id="override-by-css" tabindex="-1">Override by CSS</h4><p>You can directly override these CSS variables in the code, and the style of the Button component will change accordingly:</p><pre><code class="language-css"><span class="hljs-comment">/* the Primary Button will turn red */</span>
|
|
<span class="hljs-selector-pseudo">:root</span> {
|
|
<span class="hljs-attr">--van-button-primary-background-color</span>: red;
|
|
}
|
|
</code></pre><h4 id="override-by-configprovider" tabindex="-1">Override by ConfigProvider</h4><p>The <code>ConfigProvider</code> component provides the ability to override CSS variables. You need to wrap a <code>ConfigProvider</code> component at the root node and configure some CSS variables through the <code>theme-vars</code> property.</p><pre><code class="language-html"><span class="hljs-tag"><<span class="hljs-name">van-config-provider</span> <span class="hljs-attr">:theme-vars</span>=<span class="hljs-string">"themeVars"</span>></span>
|
|
<span class="hljs-tag"><<span class="hljs-name">van-form</span>></span>
|
|
<span class="hljs-tag"><<span class="hljs-name">van-field</span> <span class="hljs-attr">name</span>=<span class="hljs-string">"rate"</span> <span class="hljs-attr">label</span>=<span class="hljs-string">"Rate"</span>></span>
|
|
<span class="hljs-tag"><<span class="hljs-name">template</span> #<span class="hljs-attr">input</span>></span>
|
|
<span class="hljs-tag"><<span class="hljs-name">van-rate</span> <span class="hljs-attr">v-model</span>=<span class="hljs-string">"rate"</span> /></span>
|
|
<span class="hljs-tag"></<span class="hljs-name">template</span>></span>
|
|
<span class="hljs-tag"></<span class="hljs-name">van-field</span>></span>
|
|
<span class="hljs-tag"><<span class="hljs-name">van-field</span> <span class="hljs-attr">name</span>=<span class="hljs-string">"slider"</span> <span class="hljs-attr">label</span>=<span class="hljs-string">"Slider"</span>></span>
|
|
<span class="hljs-tag"><<span class="hljs-name">template</span> #<span class="hljs-attr">input</span>></span>
|
|
<span class="hljs-tag"><<span class="hljs-name">van-slider</span> <span class="hljs-attr">v-model</span>=<span class="hljs-string">"slider"</span> /></span>
|
|
<span class="hljs-tag"></<span class="hljs-name">template</span>></span>
|
|
<span class="hljs-tag"></<span class="hljs-name">van-field</span>></span>
|
|
<span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">style</span>=<span class="hljs-string">"margin: 16px"</span>></span>
|
|
<span class="hljs-tag"><<span class="hljs-name">van-button</span> <span class="hljs-attr">round</span> <span class="hljs-attr">block</span> <span class="hljs-attr">type</span>=<span class="hljs-string">"primary"</span> <span class="hljs-attr">native-type</span>=<span class="hljs-string">"submit"</span>></span>
|
|
Submit
|
|
<span class="hljs-tag"></<span class="hljs-name">van-button</span>></span>
|
|
<span class="hljs-tag"></<span class="hljs-name">div</span>></span>
|
|
<span class="hljs-tag"></<span class="hljs-name">van-form</span>></span>
|
|
<span class="hljs-tag"></<span class="hljs-name">van-config-provider</span>></span>
|
|
</code></pre><pre><code class="language-js"><span class="hljs-keyword">import</span> { ref } <span class="hljs-keyword">from</span> <span class="hljs-string">'vue'</span>;
|
|
|
|
<span class="hljs-keyword">export</span> <span class="hljs-keyword">default</span> {
|
|
<span class="hljs-title function_">setup</span>(<span class="hljs-params"></span>) {
|
|
<span class="hljs-keyword">const</span> rate = <span class="hljs-title function_">ref</span>(<span class="hljs-number">4</span>);
|
|
<span class="hljs-keyword">const</span> slider = <span class="hljs-title function_">ref</span>(<span class="hljs-number">50</span>);
|
|
|
|
<span class="hljs-comment">// ThemeVars will be converted to the corresponding CSS variable</span>
|
|
<span class="hljs-comment">// For example, sliderBarHeight will be converted to \`--van-slider-bar-height\`</span>
|
|
<span class="hljs-keyword">const</span> themeVars = {
|
|
<span class="hljs-attr">rateIconFullColor</span>: <span class="hljs-string">'#07c160'</span>,
|
|
<span class="hljs-attr">sliderBarHeight</span>: <span class="hljs-string">'4px'</span>,
|
|
<span class="hljs-attr">sliderButtonWidth</span>: <span class="hljs-string">'20px'</span>,
|
|
<span class="hljs-attr">sliderButtonHeight</span>: <span class="hljs-string">'20px'</span>,
|
|
<span class="hljs-attr">sliderActiveBackgroundColor</span>: <span class="hljs-string">'#07c160'</span>,
|
|
<span class="hljs-attr">buttonPrimaryBorderColor</span>: <span class="hljs-string">'#07c160'</span>,
|
|
<span class="hljs-attr">buttonPrimaryBackgroundColor</span>: <span class="hljs-string">'#07c160'</span>,
|
|
};
|
|
|
|
<span class="hljs-keyword">return</span> {
|
|
rate,
|
|
slider,
|
|
themeVars,
|
|
};
|
|
},
|
|
};
|
|
</code></pre><blockquote><p>Tips: ConfigProvider only affects its child components.</p></blockquote></div><div class="van-doc-card"><h3 id="basic-variables" tabindex="-1">Basic Variables</h3><p>CSS variables in Vant are divided into <strong>basic variables</strong> and <strong>component variables</strong>. Component variables will inherit the basic variables. After modifying the basic variables, all related components will be affected.</p><h4 id="modify-basic-variables" tabindex="-1">Modify Basic Variables</h4><ul><li>The basic variables can only be modified through the <code>root</code> selector.</li><li>The component variables can be modified through the <code>root</code> selector and <code>ConfigProvider</code> component.</li></ul><h4 id="variable-list" tabindex="-1">Variable List</h4><p>There are all <strong>Basic Variables</strong> below, for component CSS Variables, please refer to the documentation of each component.</p><pre><code class="language-less"><span class="hljs-comment">// Color Palette</span>
|
|
<span class="hljs-attr">--van-black</span>: #000;
|
|
<span class="hljs-attr">--van-white</span>: #fff;
|
|
<span class="hljs-attr">--van-gray-1</span>: #f7f8fa;
|
|
<span class="hljs-attr">--van-gray-2</span>: #f2f3f5;
|
|
<span class="hljs-attr">--van-gray-3</span>: #ebedf0;
|
|
<span class="hljs-attr">--van-gray-4</span>: #dcdee0;
|
|
<span class="hljs-attr">--van-gray-5</span>: #c8c9cc;
|
|
<span class="hljs-attr">--van-gray-6</span>: #969799;
|
|
<span class="hljs-attr">--van-gray-7</span>: #646566;
|
|
<span class="hljs-attr">--van-gray-8</span>: #323233;
|
|
<span class="hljs-attr">--van-red</span>: #ee0a24;
|
|
<span class="hljs-attr">--van-blue</span>: #1989fa;
|
|
<span class="hljs-attr">--van-orange</span>: #ff976a;
|
|
<span class="hljs-attr">--van-orange-dark</span>: #ed6a0c;
|
|
<span class="hljs-attr">--van-orange-light</span>: #fffbe8;
|
|
<span class="hljs-attr">--van-green</span>: #07c160;
|
|
|
|
<span class="hljs-comment">// Gradient Colors</span>
|
|
<span class="hljs-attr">--van-gradient-red</span>: linear-gradient(to <span class="hljs-attribute">right, #ff6034, #ee0a24);
|
|
--van-gradient-orange</span>: <span class="hljs-built_in">linear-gradient</span>(to right, <span class="hljs-number">#ffd01e</span>, <span class="hljs-number">#ff8917</span>);
|
|
|
|
<span class="hljs-comment">// Component Colors</span>
|
|
<span class="hljs-attr">--van-primary-color</span>: var(<span class="hljs-attr">--van-blue</span>);
|
|
<span class="hljs-attr">--van-success-color</span>: var(<span class="hljs-attr">--van-green</span>);
|
|
<span class="hljs-attr">--van-danger-color</span>: var(<span class="hljs-attr">--van-red</span>);
|
|
<span class="hljs-attr">--van-warning-color</span>: var(<span class="hljs-attr">--van-orange</span>);
|
|
<span class="hljs-attr">--van-text-color</span>: var(<span class="hljs-attr">--van-gray-8</span>);
|
|
<span class="hljs-attr">--van-text-color-2</span>: var(<span class="hljs-attr">--van-gray-6</span>);
|
|
<span class="hljs-attr">--van-text-color-3</span>: var(<span class="hljs-attr">--van-gray-5</span>);
|
|
<span class="hljs-attr">--van-text-link-color</span>: #576b95;
|
|
<span class="hljs-attr">--van-active-color</span>: var(<span class="hljs-attr">--van-gray-2</span>);
|
|
<span class="hljs-attr">--van-active-opacity</span>: 0.6;
|
|
<span class="hljs-attr">--van-disabled-opacity</span>: 0.5;
|
|
<span class="hljs-attr">--van-background-color</span>: var(<span class="hljs-attr">--van-gray-1</span>);
|
|
<span class="hljs-attr">--van-background-color-light</span>: var(<span class="hljs-attr">--van-white</span>);
|
|
|
|
<span class="hljs-comment">// Padding</span>
|
|
<span class="hljs-attr">--van-padding-base</span>: 4px;
|
|
<span class="hljs-attr">--van-padding-xs</span>: 8px;
|
|
<span class="hljs-attr">--van-padding-sm</span>: 12px;
|
|
<span class="hljs-attr">--van-padding-md</span>: 16px;
|
|
<span class="hljs-attr">--van-padding-lg</span>: 24px;
|
|
<span class="hljs-attr">--van-padding-xl</span>: 32px;
|
|
|
|
<span class="hljs-comment">// Font</span>
|
|
<span class="hljs-attr">--van-font-size-xs</span>: 10px;
|
|
<span class="hljs-attr">--van-font-size-sm</span>: 12px;
|
|
<span class="hljs-attr">--van-font-size-md</span>: 14px;
|
|
<span class="hljs-attr">--van-font-size-lg</span>: 16px;
|
|
<span class="hljs-attr">--van-font-weight-bold</span>: 500;
|
|
<span class="hljs-attr">--van-line-height-xs</span>: 14px;
|
|
<span class="hljs-attr">--van-line-height-sm</span>: 18px;
|
|
<span class="hljs-attr">--van-line-height-md</span>: 20px;
|
|
<span class="hljs-attr">--van-line-height-lg</span>: 22px;
|
|
<span class="hljs-attr">--van-base-font-family</span>: -apple-system, BlinkMacSystemFont, 'Helvetica Neue',
|
|
Helvetica, Segoe UI, Arial, Roboto, 'PingFang SC', 'miui', 'Hiragino Sans GB',
|
|
'Microsoft Yahei', sans-serif;
|
|
<span class="hljs-attr">--van-price-integer-font-family</span>: Avenir-Heavy, PingFang SC, Helvetica Neue,
|
|
Arial, sans-serif;
|
|
|
|
<span class="hljs-comment">// Animation</span>
|
|
<span class="hljs-attr">--van-animation-duration-base</span>: 0.3s;
|
|
<span class="hljs-attr">--van-animation-duration-fast</span>: 0.2s;
|
|
<span class="hljs-attr">--van-animation-timing-function-enter</span>: ease-out;
|
|
<span class="hljs-attr">--van-animation-timing-function-leave</span>: ease-in;
|
|
|
|
<span class="hljs-comment">// Border</span>
|
|
<span class="hljs-attr">--van-border-color</span>: var(<span class="hljs-attr">--van-gray-3</span>);
|
|
<span class="hljs-attr">--van-border-width-base</span>: 1px;
|
|
<span class="hljs-attr">--van-border-radius-sm</span>: 2px;
|
|
<span class="hljs-attr">--van-border-radius-md</span>: 4px;
|
|
<span class="hljs-attr">--van-border-radius-lg</span>: 8px;
|
|
<span class="hljs-attr">--van-border-radius-max</span>: 999px;
|
|
</code></pre></div><h2 id="api" tabindex="-1">API</h2><div class="van-doc-card"><h3 id="props" tabindex="-1">Props</h3><table><thead><tr><th>Attribute</th><th>Description</th><th>Type</th><th>Default</th></tr></thead><tbody><tr><td>theme-vars</td><td>Theme variables</td><td><em>object</em></td><td>-</td></tr><tr><td>tag <code>v3.1.2</code></td><td>HTML Tag of root element</td><td><em>string</em></td><td><code>div</code></td></tr><tr><td>z-index <code>v3.6.0</code></td><td>Set the z-index of all popup components, this property takes effect globally</td><td><em>number</em></td><td><code>2000</code></td></tr><tr><td>icon-prefix <code>v3.1.3</code></td><td>Icon className prefix</td><td><em>string</em></td><td><code>van-icon</code></td></tr></tbody></table></div><div class="van-doc-card"><h3 id="types" tabindex="-1">Types</h3><p>The component exports the following type definitions:</p><pre><code class="language-ts"><span class="hljs-keyword">import</span> <span class="hljs-keyword">type</span> { <span class="hljs-title class_">ConfigProviderProps</span> } <span class="hljs-keyword">from</span> <span class="hljs-string">'vant'</span>;
|
|
</code></pre></div>`,10),p=[e],d={__name:"README",setup(r,{expose:s}){return s({frontmatter:{}}),(c,i)=>(a(),n("div",l,p))}};export{d as default};
|