mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-06 03:57:59 +08:00
216 lines
4.9 KiB
Markdown
216 lines
4.9 KiB
Markdown
# Custom Theme
|
||
|
||
### Deprecated
|
||
|
||
This document is deprecated. Vant provides a more convenient [ConfigProvider](#/en-US/config-provider) component for theme configuration. Less variables **will be removed in the next major version**.
|
||
|
||
### Intro
|
||
|
||
Vant use [Less](http://lesscss.org/) as css preprocessor,you can override the default less variables to custom theme.
|
||
|
||
### Less variables
|
||
|
||
There are some [basic variables](<(https://github.com/youzan/vant/blob/dev/src/style/var.less)>) below, for component less variables, please refer to the documentation of each component, or view the `var.less` file in the component source directory.
|
||
|
||
```less
|
||
// Color Palette
|
||
@black: #000;
|
||
@white: #fff;
|
||
@gray-1: #f7f8fa;
|
||
@gray-2: #f2f3f5;
|
||
@gray-3: #ebedf0;
|
||
@gray-4: #dcdee0;
|
||
@gray-5: #c8c9cc;
|
||
@gray-6: #969799;
|
||
@gray-7: #646566;
|
||
@gray-8: #323233;
|
||
@red: #ee0a24;
|
||
@blue: #1989fa;
|
||
@orange: #ff976a;
|
||
@orange-dark: #ed6a0c;
|
||
@orange-light: #fffbe8;
|
||
@green: #07c160;
|
||
|
||
// Gradient Colors
|
||
@gradient-red: linear-gradient(to right, #ff6034, #ee0a24);
|
||
@gradient-orange: linear-gradient(to right, #ffd01e, #ff8917);
|
||
|
||
// Component Colors
|
||
@text-color: @gray-8;
|
||
@active-color: @gray-2;
|
||
@active-opacity: 0.7;
|
||
@disabled-opacity: 0.5;
|
||
@background-color: @gray-1;
|
||
@background-color-light: #fafafa;
|
||
@text-link-color: #576b95;
|
||
|
||
// Padding
|
||
@padding-base: 4px;
|
||
@padding-xs: @padding-base * 2;
|
||
@padding-sm: @padding-base * 3;
|
||
@padding-md: @padding-base * 4;
|
||
@padding-lg: @padding-base * 6;
|
||
@padding-xl: @padding-base * 8;
|
||
|
||
// Font
|
||
@font-size-xs: 10px;
|
||
@font-size-sm: 12px;
|
||
@font-size-md: 14px;
|
||
@font-size-lg: 16px;
|
||
@font-weight-bold: 500;
|
||
@line-height-xs: 14px;
|
||
@line-height-sm: 18px;
|
||
@line-height-md: 20px;
|
||
@line-height-lg: 22px;
|
||
@base-font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue',
|
||
Helvetica, Segoe UI, Arial, Roboto, 'PingFang SC', 'miui', 'Hiragino Sans GB',
|
||
'Microsoft Yahei', sans-serif;
|
||
@price-integer-font-family: Avenir-Heavy, PingFang SC, Helvetica Neue, Arial,
|
||
sans-serif;
|
||
|
||
// Animation
|
||
@animation-duration-base: 0.3s;
|
||
@animation-duration-fast: 0.2s;
|
||
@animation-timing-function-enter: ease-out;
|
||
@animation-timing-function-leave: ease-in;
|
||
|
||
// Border
|
||
@border-color: @gray-3;
|
||
@border-width-base: 1px;
|
||
@border-radius-sm: 2px;
|
||
@border-radius-md: 4px;
|
||
@border-radius-lg: 8px;
|
||
@border-radius-max: 999px;
|
||
```
|
||
|
||
## How to custom theme
|
||
|
||
### Step 1: import less file
|
||
|
||
First you should import the less source file to your project. you can use babel-plugin-import to automatically import or just manually import less file.
|
||
|
||
#### Automatically import style
|
||
|
||
Configure babel plugin in babel.config.js, if you are using babel6, please manually import less file.
|
||
|
||
```js
|
||
module.exports = {
|
||
plugins: [
|
||
[
|
||
'import',
|
||
{
|
||
libraryName: 'vant',
|
||
libraryDirectory: 'es',
|
||
// specify less file path
|
||
style: (name) => `${name}/style/less`,
|
||
},
|
||
'vant',
|
||
],
|
||
],
|
||
};
|
||
```
|
||
|
||
#### Manually import style
|
||
|
||
```js
|
||
// import all styles
|
||
import 'vant/lib/index.less';
|
||
|
||
// import style of single component
|
||
import 'vant/lib/button/style/less';
|
||
```
|
||
|
||
### Step 2: modify less variables
|
||
|
||
Use [modifyVars](http://lesscss.org/usage/#using-less-in-the-browser-modify-variables) provided by less.js to modify less variables,webpack config for reference:
|
||
|
||
```js
|
||
// webpack.config.js
|
||
module.exports = {
|
||
rules: [
|
||
{
|
||
test: /\.less$/,
|
||
use: [
|
||
// ...other loaders
|
||
{
|
||
loader: 'less-loader',
|
||
options: {
|
||
lessOptions: {
|
||
modifyVars: {
|
||
// override with less vars
|
||
'text-color': '#111',
|
||
'border-color': '#eee',
|
||
// or override with less file
|
||
hack: `true; @import "your-less-file-path.less";`,
|
||
},
|
||
},
|
||
},
|
||
},
|
||
],
|
||
},
|
||
],
|
||
};
|
||
```
|
||
|
||
If you build a project by vue-cli,it can be configured in `vue.config.js`:
|
||
|
||
```js
|
||
// vue.config.js
|
||
module.exports = {
|
||
css: {
|
||
loaderOptions: {
|
||
less: {
|
||
lessOptions: {
|
||
modifyVars: {
|
||
// override with less vars
|
||
'text-color': '#111',
|
||
'border-color': '#eee',
|
||
// or override with less file
|
||
hack: `true; @import "your-less-file-path.less";`,
|
||
},
|
||
},
|
||
},
|
||
},
|
||
},
|
||
};
|
||
```
|
||
|
||
### Vite
|
||
|
||
Add the following config in `vite.config.js`.
|
||
|
||
```js
|
||
// vite.config.js
|
||
import vue from '@vitejs/plugin-vue';
|
||
import styleImport from 'vite-plugin-style-import';
|
||
|
||
export default {
|
||
css: {
|
||
preprocessorOptions: {
|
||
less: {
|
||
javascriptEnabled: true,
|
||
modifyVars: {
|
||
'text-color': '#111',
|
||
'border-color': '#eee',
|
||
},
|
||
},
|
||
},
|
||
},
|
||
resolve: {
|
||
alias: [{ find: /^~/, replacement: '' }],
|
||
},
|
||
plugins: [
|
||
vue(),
|
||
styleImport({
|
||
libs: [
|
||
{
|
||
libraryName: 'vant',
|
||
esModule: true,
|
||
resolveStyle: (name) => `vant/es/${name}/style/less`,
|
||
},
|
||
],
|
||
}),
|
||
],
|
||
};
|
||
```
|