demojavascript
框架選擇: create-react-app + mobx + webpack5 + antdesigncss
說明html
功能實現原則:使用 less 的 modifyVars 完成 antd 的主題變量替換。java
antd-theme-generator
缺點: 須要配合 LESS v2.7.x
使用,不兼容IE。node
cnpm install antd-theme-generator -S
複製代碼
color.js
根目錄下添加文件color.js
,添加配置內容:react
const path = require('path');
const { generateTheme, } = require('antd-theme-generator');
const options = {
stylesDir: path.join(__dirname, './src/css'),
antDir: path.join(__dirname, './node_modules/antd'),
varFile: path.join(__dirname, './src/css/variables.less'),
mainLessFile: path.join(__dirname, './src/css/index.less'),
themeVariables: [ //須要動態切換的主題變量
'@primary-color',
'@secondary-color',
'@text-color',
'@text-color-secondary',
'@heading-color',
'@layout-body-background'
],
indexFileName: 'index.html',
outputFilePath: path.join(__dirname, './public/color.less'), //頁面引入的主題變量文件
}
generateTheme(options).then(less => {
console.log('Theme generated successfully');
})
.catch(error => {
console.log('Error', error);
});
複製代碼
variables.less
文件:@import "~antd/lib/style/themes/default.less"; //引入antd的變量文件,實現變量的覆蓋
@primary-color: #1DA57A;
@link-color: #1DA57A;
@btn-primary-bg:#1DA57A;
複製代碼
index.html
中加入全局less
變量配置,從而使less
的modifyVars
方法能夠全局使用,切換主題時覆蓋default.less
中的變量:<!-- 使用自動生成的color.less,主要路徑與index.html文件同級 -->
<link rel="stylesheet/less" type="text/css" href="%PUBLIC_URL%/color.less" />
<script>
window.less = {
async: false,
env: 'production'
};
</script>
<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/less.js/2.7.2/less.min.js"></script>
複製代碼
package.json
,項目運行的同時完成頁面color文件的配置"scripts": {
"start": "node color && node scripts/start.js",
"build": "node color && node scripts/build.js",
"test": " node color && node scripts/test.js"
},
複製代碼
window.less.modifyVars(
{
'@primary-color': '#aaa',
'@menu-dark-item-active-bg':'#aaa',
'@link-color': '#aaa',
'@text-color':'#aaa',
'@btn-primary-bg': '#aaa',
}
)
.then(() => {
message.success('主題切換成功')
})
.catch(error => {
message.error(`主題切換失敗`);
console.log(error)
});
複製代碼
因爲以後的配置中新增的樣式須要遵循主題配置的能夠選擇使用統一變量,因此變量設置的時候,能夠添加var(--PC)
的全局變量設置webpack