基于Vue框架開發(fā)項(xiàng)目定制Ant Design主題

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

image

Ant Design Vue 的樣式變量 #

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, .85);              // 標(biāo)題色
@text-color: rgba(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, .15);  // 浮層陰影

如果以上變量不能滿足你的定制需求,可以給我們提 issue。

定制方式 #

我們使用 modifyVars 的方式來(lái)進(jìn)行覆蓋變量。
下面將針對(duì)不同的場(chǎng)景提供一些常用的定制方式。

在 webpack 中定制主題 #

我們以 webpack@4 為例進(jìn)行說(shuō)明,以下是一個(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',
+       },
+       javascriptEnabled: true,
+     },
    }],
    // ...other rules
  }],
  // ...other config
}

注意 less-loader 的處理范圍不要過(guò)濾掉 node_modules 下的 antd 包。

在 vue cli 2中定制主題 #

修改build/utils.js文件

// build/utils.js
- less: generateLoaders('less'),
+ less: generateLoaders('less', {
+   modifyVars: {
+     'primary-color': '#1DA57A',
+     'link-color': '#1DA57A',
+     'border-radius-base': '2px',
+   },
+   javascriptEnabled: true,
+ }),

在 vue cli 3中定制主題 #

項(xiàng)目更目錄下新建文件vue.config.js

// vue.config.js
module.exports = {
  css: {
    loaderOptions: {
      less: {
        modifyVars: {
          'primary-color': '#1DA57A',
          'link-color': '#1DA57A',
          'border-radius-base': '2px',
        },
        javascriptEnabled: true
      }
    }
  }
}

配置 less 變量文件 #

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

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

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

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容