Ant Design 設(shè)計(jì)規(guī)范和技術(shù)上支持靈活的樣式定制,以滿足業(yè)務(wù)和品牌上多樣化的視覺需求,包括但不限于全局樣式(主色、圓角、邊框)和指定組件的視覺定制。
antd 的樣式使用了 Less 作為開發(fā)語言,并定義了一系列全局/組件的樣式變量,你可以根據(jù)需求進(jìn)行相應(yīng)調(diào)整。
以下是一些最常用的通用變量,所有樣式變量可以在 這里 找到。
@primary-color: #1890ff; // 全局主色
@link-color: #1890ff; // 鏈接色
@success-color: #52c41a; // 成功色
@warning-color: #faad14; // 警告色
@error-color: #f5222d; // 錯(cuò)誤色
@font-size-base: 14px; // 主字號(hào)
@heading-color: rgba(0, 0, 0, 0.85); // 標(biāo)題色
@text-color: rgba(0, 0, 0, 0.65); // 主文本色
@text-color-secondary : rgba(0, 0, 0, .45); // 次文本色
@disabled-color : rgba(0, 0, 0, .25); // 失效色
@border-radius-base: 4px; // 組件/浮層圓角
@border-color-base: #d9d9d9; // 邊框色
@box-shadow-base: 0 2px 8px rgba(0, 0, 0, 0.15); // 浮層陰影
如果以上變量不能滿足你的定制需求,可以給我們提 issue。
原理上是使用 less 提供的 modifyVars 的方式進(jìn)行覆蓋變量,可以在本地運(yùn)行 例子 查看定制效果。下面將針對(duì)不同的場(chǎng)景提供一些常用的定制方式。
我們以 webpack@4 為例進(jìn)行說明,以下是一個(gè) webpack.config.js 的典型例子,對(duì) less-loader 的 options 屬性進(jìn)行相應(yīng)配置。
// webpack.config.js
module.exports = {
rules: [{
test: /\.less$/,
use: [{
loader: 'style-loader',
}, {
loader: 'css-loader', // translates CSS into CommonJS
}, {
loader: 'less-loader', // compiles Less to CSS
+ options: {
+ modifyVars: {
+ 'primary-color': '#1DA57A',
+ 'link-color': '#1DA57A',
+ 'border-radius-base': '2px',
+ // or
+ 'hack': `true; @import "your-less-file-path.less";`, // Override with less file
+ },
+ javascriptEnabled: true,
+ },
}],
// ...other rules
}],
// ...other config
}
注意 less-loader 的處理范圍不要過濾掉 node_modules 下的 antd 包。
如果你在使用 Umi,那么可以很方便地在項(xiàng)目根目錄的 config/config.js(Umi)文件中 theme 字段進(jìn)行主題配置。theme 可以配置為一個(gè)對(duì)象或文件路徑。
"theme": {
"primary-color": "#1DA57A",
},
或者 一個(gè) js 文件:
"theme": "./theme.js",
參考 在 create-react-app 中使用 進(jìn)行配置即可。
另外一種方式是建立一個(gè)單獨(dú)的 less 變量文件,引入這個(gè)文件覆蓋 antd.less 里的變量。
@import '~antd/dist/antd.less'; // 引入官方提供的 less 樣式入口文件
@import 'your-theme-file.less'; // 用于覆蓋上面定義的變量
注意,這種方式已經(jīng)載入了所有組件的樣式,不需要也無法和按需加載插件 babel-plugin-import 的 style 屬性一起使用。
注意樣式必須加載 less 格式,一個(gè)常見的問題就是引入了多份樣式,less 的樣式被 css 的樣式覆蓋了。
我們提供了一些官方主題,歡迎在項(xiàng)目中試用,并且給我們提供反饋。
更多建議: