老板让换肤?经理让换肤?....我就喜欢我黑,我不想变白!

三个月前,我接到了需求,在新项目中完成动态换肤功能。
当时我的项目是这样的:

vue2 + less

我专门定义了一个default.less文件存储了公共的颜色变量,要求开发人员使用公共变量开发less样式文件。我认为如果实现换肤,我只需要切换这个公共的less即可实现动态换肤。
当时我们的项目引用了ant组件,因此我在main.js中按照ant官方给的主题切换方法,配置了default.less;

在main.js中引入:

import "~ant-design-vue/dist/antd.less"; // ant
import "./assets/css/style/default.less"; // 皮肤控制

两个月后,我准备开始处理换肤的功能,于是我在思考,如何动态切换这里引入的文件default.less为light.less,绞尽脑汁,我用到了loadingStore,在main.js中做了if判断:

import "~ant-design-vue/dist/antd.less"; // ant
if(loadingStore.getItem("skin") === "default"){
  import("./assets/css/style/default.less"); // 皮肤控制
}else{
  import("./assets/css/style/light.less"); // 皮肤控制
}

努力终将有回报,甭管代码漂不漂亮,我发现能换了,当我高兴的时候,我提醒自己发布一版看一看!
结果三观被击毁!
less是预编译语言,打包的过程中,已经完美的生成了一个漂亮的css文件。怎么切换?从何切换?
我的服务器是nginx,不是我本地的开发软件。

于是我开始重新思索,如何切换,我认为自己的逻辑没有问题,通过公共两套的less变量控制不同的皮肤。
查资料,问高人,最终发现一个可行的方案:

创建style.less内容如下:

.default{
  @import '~ant-design-vue/dist/antd.less'; // 引入官方提供的 less 样式入口文件
  @import 'default.less'; // 用于覆盖上面定义的变量
}
.light{
  @import '~ant-design-vue/dist/antd.less'; // 引入官方提供的 less 样式入口文件
  @import 'light.less'; // 用于覆盖上面定义的变量
}

在main.js中引入:

import "./assets/css/style/style.less"; // 主题控制

我只需要动态切换default和light两个不同的样式。
通过努力,我成功了,class跟随变化,但是,ant跪了。
是的跪了,我默认皮肤进来后没有问题,点击切换皮肤,ant跪了,因为有部分的ant组件如转圈圈(Spin)不动了,它们占据了我的屏幕。
此时我发现我似乎忘记了什么?不能同时引入同一个less?我做了尝试,在node_modules复制了ant-design-vue2,然后改了light的引入路径。

style.less内容如下:

.default{
  @import '~ant-design-vue/dist/antd.less'; // 引入官方提供的 less 样式入口文件
  @import 'default.less'; // 用于覆盖上面定义的变量
}
.light{
  @import '~ant-design-vue2/dist/antd.less'; // 引入官方提供的 less 样式入口文件
  @import 'light.less'; // 用于覆盖上面定义的变量
}

OK了,完美的实现了换肤功能?。。?!

但是我又高兴早了,虽然项目基于ant的UI框架开发,但是有很多地方我们依然是自己手写组件,我还有除ant之外的一大堆less文件,这些地方没有跟随变化。
我不能因为换肤,要求所有同事,把所有的less全部对接两套,那样改目录结构,改图片引用路径将会让人疯掉。

天那?。?!为什么我的项目没有从头到尾依赖antUI?或者为什么当初不能全部摒弃,自己手写所有的UI组件?
有经验的大佬们都晓得,纯手写不是不可能,但是时间是一个大问题,没有哪个项目会静静的等你写一个新的Ant2?等你写出来黄花菜都凉了。因此使用现成的UI框架是一个省心省力的过程,但是大家也明白,没有人会整个项目全部使用它的组件开发,毕竟多有冲突和不便,设计师的灵魂都是飞舞的,需求的变态都是超级辣的,很多时候,写一个比改一个要容易的多。

后续:另一种思路,我认为vue打包样式,应该可以通过某种方式生成两套css样式文件,我只需要切换这两套文件即可。研究中....是否成功,且走且瞧着,说不定老板一高兴,不弄了!哈哈哈哈!

@import指令

学习不能停!?。。?br> 关于less中的@import指令:

选项 含义
reference 使用文件,但不会输出其内容(即,文件作为样式库使用)
inline 对文件的内容不作任何处理,直接输出
less 无论文件的扩展名是什么,都将作为LESS文件被输出
css 无论文件的扩展名是什么,都将作为CSS文件被输出
once 文件仅被导入一次 (这也是默认行为)
multiple 文件可以被导入多次
optional 当文件不存在时,继续编译(即,该文件是可选的)

例如:

@import (optional, reference) "foo.less";
最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,128评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,316评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,737评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,283评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,384评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,458评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,467评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,251评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,688评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,980评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,155评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,818评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,492评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,142评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,382评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,020评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,044评论 2 352

推荐阅读更多精彩内容