## 定制主题

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

### 方案一. PostCSS 插件
在项目中直接引入组件对应的 postcss 源代码，并通过 postcss 插件 [postcss-theme-variables](https://www.npmjs.com/package/postcss-theme-variables) 替换颜色变量，步骤如下：

```javascript
// 引入基础样式
import 'ifu/packages/ifu-css/src/base.css';

// 引入组件对应的样式
import 'ifu/packages/ifu-css/src/button.css';
import 'ifu/packages/ifu-css/src/checkbox.css';
```

接着在 postcss.config.js 中引入所需的 postcss 插件，并根据项目需求配置颜色变量，所有可用的颜色变量请参考 [配置文件](https://github.com/youzan/ifu/blob/dev/packages/ifu-css/src/common/var.css)

```javascript
module.exports = {
  plugins: [
    require('postcss-easy-import')({
      extensions: ['pcss', 'css']
    }),
    require('postcss-theme-variables')({
      vars: {
        red: '#F60',
        gray: '#CCC',
        blue: '#03A9F4'
      },
      prefix: '$'
    }),
    require('precss')(),
    require('postcss-calc')(),
    require('autoprefixer')({
      browsers: ['Android >= 4.0', 'iOS >= 7']
    })
  ]
};
```

> 注意: precss2 和 3 版本不兼容, 请将precss的版本改为2.0.0

### 方案二. 本地构建
可以通过在本地构建 ifu-css 的方式生成所需的主题

```bash
# 克隆仓库
git clone git@github.com:youzan/ifu.git
cd packages/ifu-css
```

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

