react实现antd线上主题动态切换功能


Posted in Javascript onAugust 12, 2019

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="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) 的全局变量设置

总结

以上所述是小编给大家介绍的react实现antd线上主题动态切换功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
Javascript代码混淆综合解决方案-Javascript在线混淆器
Dec 18 Javascript
json 定义
Jun 10 Javascript
js点击更换背景颜色或图片的实例代码
Jun 25 Javascript
js实现的常用的左侧导航效果
Oct 17 Javascript
JS判断两个时间大小的示例代码
Jan 28 Javascript
js实现漂浮回顶部按钮实例
May 06 Javascript
利用Vue.js+Node.js+MongoDB实现一个博客系统(附源码)
Apr 24 Javascript
详解plotly.js 绘图库入门使用教程
Feb 23 Javascript
postman+json+springmvc测试批量添加实例
Mar 31 Javascript
解决vue2 在mounted函数无法获取prop中的变量问题
Nov 15 Javascript
JavaScript遍历DOM元素的常见方式示例
Feb 16 Javascript
es6中new.target的作用和使用场景简单示例分析
Mar 14 Javascript
vue从一个页面跳转到另一个页面并携带参数的解决方法
Aug 12 #Javascript
解析原来浏览器原生支持JS Base64编码解码
Aug 12 #Javascript
在vue-cli 3中给stylus、sass样式传入共享的全局变量
Aug 12 #Javascript
微信小程序实现页面跳转传递参数(实体,对象)
Aug 12 #Javascript
微信小程序实现传递多个参数与事件处理
Aug 12 #Javascript
node命令行工具之实现项目工程自动初始化的标准流程
Aug 12 #Javascript
五分钟搞懂Vuex实用知识(小结)
Aug 12 #Javascript
You might like
2020年4月新番动漫目录 官方宣布4月播出的作品一览
2020/03/08 日漫
php 运行效率总结(提示程序速度)
2009/11/26 PHP
PHP 获取远程网页内容的代码(fopen,curl已测)
2011/06/06 PHP
在Laravel中使用GuzzleHttp调用第三方服务的API接口代码
2019/10/15 PHP
div拖拽插件——JQ.MoveBox.js(自制JQ插件)
2013/05/17 Javascript
使用GruntJS构建Web程序之Tasks(任务)篇
2014/06/06 Javascript
jQuery实现异步获取json数据的2种方式
2014/08/29 Javascript
用js读、写、删除Cookie代码续篇
2014/12/03 Javascript
javascript动态创建及删除元素的方法
2014/12/22 Javascript
基于JQuery实现图片上传预览与删除操作
2016/05/24 Javascript
Js 获取当前函数参数对象的实现代码
2016/06/20 Javascript
AngularJs Dependency Injection(DI,依赖注入)
2016/09/02 Javascript
微信小程序 wxapp导航 navigator详解
2016/10/31 Javascript
js实现用户输入的小写字母自动转大写字母的方法
2017/01/21 Javascript
详解vue与后端数据交互(ajax):vue-resource
2017/03/16 Javascript
详解Vue 方法与事件处理器
2017/06/20 Javascript
微信小程序支付PHP代码
2018/08/23 Javascript
如何使用webpack打包一个库library的方法步骤
2019/12/18 Javascript
Vue路由管理器Vue-router的使用方法详解
2020/02/05 Javascript
详解Java中String JSONObject JSONArray List转换
2020/11/13 Javascript
详解node.js创建一个web服务器(Server)的详细步骤
2021/01/15 Javascript
对numpy中的transpose和swapaxes函数详解
2018/08/02 Python
pycharm恢复默认设置或者是替换pycharm的解释器实例
2018/10/29 Python
在python中pandas的series合并方法
2018/11/12 Python
结束运行python的方法
2020/06/16 Python
Python爬虫自动化获取华图和粉笔网站的错题(推荐)
2021/01/08 Python
Python之qq自动发消息的示例代码
2021/02/18 Python
世界首屈一指的在线男士内衣权威:HisRoom
2017/08/05 全球购物
会议活动邀请函
2014/01/27 职场文书
志愿者活动总结
2014/04/28 职场文书
奖学金个人总结
2015/03/04 职场文书
工厂仓库管理员岗位职责
2015/04/09 职场文书
同学聚会感言一句话
2015/07/30 职场文书
Python如何配置环境变量详解
2021/05/18 Python
linux下安装redis图文详细步骤
2021/12/04 Redis
Windows和Linux上部署Golang并运行程序
2022/04/22 Servers