Ant Design React 定制主題

2023-09-26 11:53 更新

Ant Design 設(shè)計(jì)規(guī)范和技術(shù)上支持靈活的樣式定制,以滿足業(yè)務(wù)和品牌上多樣化的視覺需求,包括但不限于全局樣式(主色、圓角、邊框)和指定組件的視覺定制。

一些配置好的主題

Ant Design 的樣式變量

antd 的樣式使用了 Less 作為開發(fā)語(yǔ)言,并定義了一系列全局/組件的樣式變量,你可以根據(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 中定制主題

我們以 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 里配置主題

如果你在使用 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 中定制主題

參考 在 create-react-app 中使用 進(jìn)行配置即可。

配置 less 變量文件

另外一種方式是建立一個(gè)單獨(dú)的 less 變量文件,引入這個(gè)文件覆蓋 antd.less 里的變量。

@import '~antd/dist/antd.less'; // 引入官方提供的 less 樣式入口文件
@import 'your-theme-file.less'; // 用于覆蓋上面定義的變量

注意,這種方式已經(jīng)載入了所有組件的樣式,不需要也無(wú)法和按需加載插件 babel-plugin-import 的 style 屬性一起使用。

沒有生效?

注意樣式必須加載 less 格式,一個(gè)常見的問題就是引入了多份樣式,less 的樣式被 css 的樣式覆蓋了。

  • 如果你在使用 babel-plugin-import 的 style 配置來(lái)引入樣式,需要將配置值從 'css' 改為 true,這樣會(huì)引入 less 文件。
  • 如果你是通過 'antd/dist/antd.css' 引入樣式的,改為 antd/dist/antd.less。

官方主題 ??

我們提供了一些官方主題,歡迎在項(xiàng)目中試用,并且給我們提供反饋。

社區(qū)教程


以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)