mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-06 03:57:59 +08:00
103 lines
2.5 KiB
Markdown
103 lines
2.5 KiB
Markdown
# 定制主题
|
||
|
||
### 介绍
|
||
|
||
Vant 提供了一套默认主题,CSS 命名采用 BEM 的风格,方便使用者覆盖样式。如果你想完全替换主题色或者其他样式,可以使用下面提供的方法
|
||
|
||
### 示例工程
|
||
|
||
我们提供了一个基于 Vue Cli 3 的示例工程,仓库地址为 [Vant Demo](https://github.com/youzan/vant-demo),其中包含了定制主题的基本配置,可以作为参考。
|
||
|
||
### 样式变量
|
||
|
||
Vant 使用了 [Less](http://lesscss.org/) 对样式进行预处理,并内置了一些样式变量,通过替换样式变量即可定制你自己需要的主题。
|
||
|
||
下面是一些基本的样式变量,所有可用的颜色变量请参考 [配置文件](https://github.com/youzan/vant/blob/dev/packages/style/var.less)。
|
||
|
||
```less
|
||
// color variables
|
||
@black: #000;
|
||
@white: #fff;
|
||
@red: #f44;
|
||
@blue: #1989fa;
|
||
@orange: #ff976a;
|
||
@orange-dark: #ed6a0c;
|
||
@orange-light: #fffbe8;
|
||
@green: #07c160;
|
||
@gray: #c9c9c9;
|
||
@gray-light: #e5e5e5;
|
||
@gray-darker: #7d7e80;
|
||
@gray-dark: #969799;
|
||
|
||
// default colors
|
||
@text-color: #323233;
|
||
@border-color: #ebedf0;
|
||
@active-color: #f2f3f5;
|
||
@background-color: #f8f8f8;
|
||
@background-color-light: #fafafa;
|
||
```
|
||
|
||
### 定制方法
|
||
|
||
定制主题分为两步:引入样式源文件和修改样式变量
|
||
|
||
#### 步骤一. 引入样式源文件
|
||
|
||
Vant 支持通过 babel 插件按需引入和手动引入两种方式,推荐使用按需引入的方式。
|
||
|
||
```js
|
||
// 在 babel.config.js 中配置按需引入样式源文件
|
||
// 注意:babel6 不支持按需引入样式,请手动引入
|
||
module.exports = {
|
||
plugins: [
|
||
[
|
||
'import',
|
||
{
|
||
libraryName: 'vant',
|
||
libraryDirectory: 'es',
|
||
// 指定样式路径
|
||
style: name => `${name}/style/less`
|
||
},
|
||
'vant'
|
||
]
|
||
]
|
||
};
|
||
```
|
||
|
||
下面是手动引入的方法:
|
||
|
||
```js
|
||
// 手动引入组件的样式源文件
|
||
import Button from 'vant/lib/button';
|
||
import 'vant/lib/button/style/less';
|
||
```
|
||
|
||
#### 步骤二. 修改样式变量
|
||
|
||
使用 less 提供的 [modifyVars](http://lesscss.org/usage/#using-less-in-the-browser-modify-variables) 即可对变量进行修改,下面是参考的 webpack 配置。
|
||
|
||
```js
|
||
// webpack.config.js
|
||
module.exports = {
|
||
rules: [
|
||
{
|
||
test: /\.less$/,
|
||
use: [
|
||
// ...other loaders
|
||
{
|
||
loader: 'less-loader',
|
||
options: {
|
||
modifyVars: {
|
||
red: '#03a9f4',
|
||
blue: '#3eaf7c',
|
||
orange: '#f08d49',
|
||
'text-color': '#111'
|
||
}
|
||
}
|
||
}
|
||
]
|
||
}
|
||
]
|
||
};
|
||
```
|