使用vue + less 实现简单换肤功能的示例


Posted in Javascript onFebruary 21, 2018

做的换肤效果比较简单,只是顶部导航背景色的改变。下面是效果图。

使用vue + less 实现简单换肤功能的示例 

首先,先说一下我最初的思路。

我最初的想法是使用less定义变量,然后通过js来切换变量,通过切换的变量来达到换肤的效果。

我先新建了一个 theme.less文件,代码如下:

@theme:@themea;
 @themea:pink;
 @themeb:blue;
 @themec:gray;

如我最开始的想法,应该是通过点击事件来改变变量 @theme 的值。

我用了element-ui这个框架,所以我的下拉菜单的代码也不复杂:

<el-dropdown class="colorBtn " trigger="click" @command="changeColor">
 <span class="el-dropdown-link " >换肤</span>
 <el-dropdown-menu slot="dropdown">
 <el-dropdown-item command="a" @click="change_type(a)">梦幻粉</el-dropdown-item>
 <el-dropdown-item command="b" @click="change_type(b)">天空蓝</el-dropdown-item>
 <el-dropdown-item command="c" @click="change_type(c)">雾霾灰</el-dropdown-item>
 </el-dropdown-menu>
</el-dropdown>

点击事件的回调事件绑定在command事件,我定义了一个changeColor的方法

changeColor(command){
  console.log(command);//能获取到当前点击的元素的command
 }

于是,问题来了,我怎么通过点击事件来改变@theme的值呢?我陷入了沉(搜)思(索)……

终于找到了一个迂回解决问题的方法,其实一开始的想法也没有问题,但是需要再包装一层。怎么包装呢?我们虽然暂时控制不了变量值,但是我们可以控制元素的类名。

我们可以将换肤的部分抽出来用less函数来表示,将theme.less代码改成下面代码

其中 @backcolor是背景色,@fcolor是字体颜色

.theme(@backcolor:#EEA2AD,@fcolor:#fff) {
 .header {
 color: @fcolor;
 background: @backcolor;
 width: 100%;
 height: 2rem;
 position: relative;

 h4 {
  width: 100%;
  text-align: center;
  line-height: 2rem;
  font-size: 1rem;
 }
 .go-back {
  width: 2rem;
  height: 2rem;
  text-align: center;
  color: #fff;
  font-size: 0.8rem;
  float: left;
  line-height: 2rem;
  margin-left: 1rem;
  position: absolute;
  left: 0;
  top: 0;
 }
 .header-cont {
  width: 100%;
  text-align: center;
  line-height: 2rem;
  font-size: 1rem;
  color: #fff;
 }
 .colorBtn {
  width: 2rem;
  height: 2rem;
  text-align: center;
  color: #fff;
  font-size: 0.8rem;
  line-height: 2rem;
  margin-right: 1rem;
  position: absolute;
  top: 0;
  right: 0;
 }
 }
}

新建一个color.less,设置几种不同的皮肤样式。这里不同的皮肤样式,我用themea,themeb,themec….来表示,对应组件中的command值。当我点击粉色的时候,调用相应的函数给元素添加相对应的类名。不要忘记引用 theme.less

@import url('./theme.less');
  .themea{
   .theme();//默认的样式
  }
  .themeb{
   .theme(blue,#fff);
  }
  .themec{
   .theme(#111,#999);
  }

当点击换肤的下拉菜单时,调用的changeColor方法需要给元素添加不同的类名,当然color.less文件记得引用。

changeColor(command){
  console.log(command);
  document.getElementById('app').className ='theme'+command ;
 }

在这一块的时候,刚开始我也遇到一个问题,就是我刚开始只将这个页面的样式单独抽了出来,所以其他组件的头部样式并没有改变。我的第一个想法竟然是使用cookie,额,后来想着既然是单页面,那我将样式绑定在比较顶层的元素上,是不是可以?

结果,显而易见!!!

如果要记住上一次换的皮肤,我使用的是localStorage,将每次点击换肤的主题记录下来,然后再页面渲染之前判断是否有这个主题就可以了。效果如下

使用vue + less 实现简单换肤功能的示例 

以上这篇使用vue + less 实现简单换肤功能的示例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery ajax abort()的使用方法
Oct 28 Javascript
另一个javascript小测验(代码集合)
Jul 27 Javascript
jQuery EasyUI API 中文文档 - Tree树使用介绍
Nov 19 Javascript
jQuery事件绑定.on()简要概述及应用
Feb 07 Javascript
javascript中sort()的用法实例分析
Jan 30 Javascript
xmlplus组件设计系列之路由(ViewStack)(7)
May 02 Javascript
让微信小程序支持ES6中Promise特性的方法详解
Jun 13 Javascript
解决vue+webpack打包路径的问题
Mar 06 Javascript
vue-cli 脚手架基于Nightwatch的端到端测试环境的过程
Sep 30 Javascript
jquery实现动态添加附件功能
Oct 23 jQuery
jQuery选择器之基本选择器用法实例分析
Feb 19 jQuery
为什么node.js不适合大型项目
Apr 28 Javascript
利用angular、react和vue实现相同的面试题组件
Feb 19 #Javascript
jQuery实现滚动到底部时自动加载更多的方法示例
Feb 18 #jQuery
Angular实现的进度条功能示例
Feb 18 #Javascript
Angular2.0实现modal对话框的方法示例
Feb 18 #Javascript
JS实现运动缓冲效果的封装函数示例
Feb 18 #Javascript
Vue底层实现原理总结
Feb 17 #Javascript
js实现控制文件拖拽并获取拖拽内容功能
Feb 17 #Javascript
You might like
层叠菜单的动态生成
2006/10/09 PHP
php中var_export与var_dump的区别分析
2010/08/21 PHP
ThinkPHP实现递归无级分类――代码少
2015/07/29 PHP
PHP设计模式之简单投诉页面实例
2016/02/24 PHP
Javascript 去除数组的重复元素
2010/05/04 Javascript
js获取指定的cookie的具体实现
2014/02/20 Javascript
Seajs的学习笔记
2014/03/04 Javascript
自己使用jquery写的一个无缝滚动的插件
2014/04/30 Javascript
js控制当再次点击按钮时的间隔时间
2014/06/03 Javascript
jquery datatable后台封装数据示例代码
2014/08/07 Javascript
html的DOM中Event对象onblur事件用法实例
2015/01/21 Javascript
Bootstrap打造一个左侧折叠菜单的系统模板(二)
2016/05/17 Javascript
jQuery Ztree行政地区树状展示(点击加载)
2016/11/09 Javascript
AngularJS中一般函数参数传递用法分析
2016/11/22 Javascript
jquery 手势密码插件
2017/03/17 Javascript
详解Vue.js v-for不支持IE9的解决方法
2018/12/29 Javascript
jQuery中DOM操作原则实例分析
2019/08/01 jQuery
python解析中国天气网的天气数据
2014/03/21 Python
python实现ID3决策树算法
2017/12/20 Python
python日期时间转为字符串或者格式化输出的实例
2018/05/29 Python
Python分割指定页数的pdf文件方法
2018/10/26 Python
简单了解Pandas缺失值处理方法
2019/11/16 Python
flask框架渲染Jinja模板与传入模板变量操作详解
2020/01/25 Python
Python实现新型冠状病毒传播模型及预测代码实例
2020/02/05 Python
Pycharm中如何关掉python console
2020/10/27 Python
护士自荐信范文
2013/12/15 职场文书
宠物店的创业计划书范文
2014/01/11 职场文书
秋季运动会稿件
2014/01/30 职场文书
模具专业自荐信
2014/05/29 职场文书
见习期个人总结
2015/03/05 职场文书
交通事故赔偿起诉书
2015/05/20 职场文书
客户答谢会致辞
2015/07/30 职场文书
Nginx使用X-Accel-Redirect实现静态文件下载的统计、鉴权、防盗链、限速等
2021/04/04 Servers
python中的plt.cm.Paired用法说明
2021/05/31 Python
分享提高 Python 代码的可读性的技巧
2022/03/03 Python
浅析Python OpenCV三种滤镜效果
2022/04/11 Python