web应用程序,切换主题,给其换肤,是一个比较常见的需求。css
快速切换主题这个需求,它考验了项目的CSS代码,是否具备可维护性、可扩展性。
css要如何编写,才能达到这两点呢,我还在研究学习当中,能够参考在大型项目中组织CSS。
原本,此文想写这个的,发现道行不够(┬_┬),我仍是写如何实现的,比较好。html
想要换主色调,其实就是换一种风格样式,最终都是换css。
我看目前比较流行的几种切换主题的方式:vue
我目前用的是第一种方式,把操做过程记录下来,方便之后查看。node
说明:此项目UI是在elementUI基础上创建的,因此,咱们能够经过element提供的方法,来自定义主题。git
使用工具下载自定义主题文件,并命名为wq-variables.css
。之后咱们若是想要增长主题文件,只须要修改变量文件中各个变量所对应的值。github
咱们利用工具来编译主题。
在终端,将刚刚修改好的变量文件,经过命令node_modules/.bin/et -c wq-variables.css
来编译主题。web
默认状况下,编译的主题目录会放在./theme
下。因为,咱们是经过改变css的命名空间来切换主题的,那么,咱们就须要为刚生成的主题增长命名空间。主题文件内容不少,若是手动一个个添加命名空间,工做量巨大,这个时候,可使用另外一个给css增长命名空间的工具。下载这个项目,而后只须要修改gulpfile.js
文件中3处内容,就能够获得想要的内容,这里注意,本项目css自定义的命名空间统一为custom-******
,其中******
建议使用主题色的16进制编码,也可使用其余字符串,可是要和radio标签统一。gulp
自定义主题文件,已经有了,只剩下如何引入使用了。segmentfault
App.vue
中import新增的主题样式(这个也能够写在topbar.vue文件中,到底哪一种好些,我也不清楚)./src/components/nav/topbar/topbar.vue
中,添加对应的radio标签能够新建一个css文件,而后在其中编写样式,以后在入口文件引入就ok了。工具
具体效果,可查看于此网站:
http://weiqinl.com/vue-element-admin/
此作法参考于:
基于Element的动态换肤