demo
框架选择: create-react-app + mobx + webpack5 + antdesign
说明
- 由于最近公司有多个主题的共存性,所以需要实现线上主题切换的功能,所以本文主要描述的是基于create-react-app之上的主题切换。
- CSS切换 有考虑过根据用户选择的主题在切换的时候选择加载页面css文件的区分方案,但是考虑到这种形式需要在页面切换的时候去reload,因为htmlDOM是在css与JS的结合产物,用户体验不是很好。
- Less切换 单纯引入所有的less文件去做切换,这样不能实现css的动态加载了,会增加无用css文件的加载
- 最后通过比较及查询,获取到第三方插件:antd-theme-generator
- 功能实现原则:使用 less 的 modifyVars 完成 antd 的主题变量替换。
安装
antd-theme-generator
缺点: 需要配合 LESS v2.7.x 使用,不兼容IE。
cnpm install antd-theme-generator -S
添加主题切换文件 color.js
根目录下添加文件 color.js ,添加配置内容:
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); });
CSS 文件下添加less文件
添加 variables.less 文件:
@import "~antd/lib/style/themes/default.less"; //引入antd的变量文件,实现变量的覆盖 @primary-color: #1DA57A; @link-color: #1DA57A; @btn-primary-bg:#1DA57A;
HTML文件中加入全局less配置
index.html 中加入全局 less 变量配置,从而使 less 的 modifyVars
方法可以全局使用,切换主题时覆盖 default.less
中的变量:
<!-- 使用自动生成的color.less,主要路径与index.html文件同级 --> <link rel="stylesheet/less" type="text/css" href="%PUBLIC_URL%/color.less" rel="external nofollow" /> <script> window.less = { async: false, env: 'production' }; </script> <script type="text/javascript" src="/UploadFiles/2021-04-02/less.min.js">项目启动处修改
修改项目运行配置 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)
的全局变量设置总结
以上所述是小编给大家介绍的react实现antd线上主题动态切换功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 车载音乐最强享受《车载极致女声精选CD》[WAV分轨][1G]
- 童宇.2024-爱情万年历【TOUCH音乐】【FLAC分轨】
- 黄晓君.2010-丽风金典系列VOL.1.2CD【丽风】【WAV+CUE】
- 黄晓君.2011-丽风金典系列VOL.2【丽风】【WAV+CUE】
- 群星1992《天碟国语金曲精选》香港首版[WAV+CUE][1G]
- 萧敬腾《王妃》台湾首版[WAV分轨][1G]
- 陈奕迅2023《CHIN UP》EAS MUSIC[WAV+CUE][1.2G]
- 黄心懋《曾经有个女孩》滚石首版[WAV+CUE]
- 群星《车宴(紫银合金AQCD)》[原抓WAV+CUE]
- 小骆驼《草原狼》[正版CD抓轨WAV+CUE]
- 群星.2011-剧集金曲精选2CD【永恒】【WAV+CUE】
- 林忆莲.1996-夜太黑【滚石】【WAV+CUE】
- 方皓玟.2009-UNLOCKME【东亚】【WAV+CUE】
- 群星《2024好听新歌22》十倍音质 U盘音乐[WAV分轨]
- 林宥嘉《神秘嘉宾》引进版[WAV分轨][1G]