定制主题

Vant提供了一套默认主题,CSS 命名采用 BEM 的风格,方便使用者覆盖样式。如果你想完全替换主题色或者其他样式,可以使用下面的方法:

方案一. PostCSS 插件

在项目中直接引入组件对应的 postcss 源代码,并通过 postcss 插件 postcss-theme-variables 替换颜色变量,步骤如下:

  1. // 引入基础样式
  2. import 'vant/packages/vant-css/src/base.css';
  3. // 引入组件对应的样式
  4. import 'vant/packages/vant-css/src/button.css';
  5. import 'vant/packages/vant-css/src/checkbox.css';

接着在 postcss.config.js 中引入所需的 postcss 插件,并根据项目需求配置颜色变量,所有可用的颜色变量请参考 配置文件

  1. module.exports = {
  2. plugins: [
  3. require('postcss-easy-import')({
  4. extensions: ['pcss', 'css']
  5. }),
  6. require('postcss-theme-variables')({
  7. vars: {
  8. red: '#F60',
  9. gray: '#CCC',
  10. blue: '#03A9F4'
  11. },
  12. prefix: '- '
  13. }),
  14. require('precss')(),
  15. require('postcss-calc')(),
  16. require('autoprefixer')({
  17. browsers: ['Android >= 4.0', 'iOS >= 7']
  18. })
  19. ]
  20. };
注意: precss2 和 3 版本不兼容, 请将precss的版本改为2.0.0

方案二. 本地构建

可以通过在本地构建 vant-css 的方式生成所需的主题

  1. # 克隆仓库
  2. git clone git@github.com:youzan/vant.git
  3. cd packages/vant-css

在本地 vant-css 仓库中,修改 src/common/var.css 中的颜色变量,然后执行以下构建命令,即可生成对应的样式文件

  1. npm run build

原文:

https://youzan.github.io/vant/#/zh-CN/theme