使用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 相关文章推荐
node.js中的fs.exists方法使用说明
Dec 17 Javascript
学习Javascript面向对象编程之封装
Feb 23 Javascript
JS中this上下文对象使用方式
Oct 09 Javascript
jquery dataTable 获取某行数据
May 05 jQuery
快速理解 JavaScript 中的 LHS 和 RHS 查询的用法
Aug 24 Javascript
js Dom实现换肤效果
Oct 21 Javascript
jQuery实现的两种简单弹窗效果示例
Apr 18 jQuery
脚手架vue-cli工程webpack的作用和特点
Sep 29 Javascript
mpvue开发音频类小程序踩坑和建议详解
Mar 12 Javascript
JS实现的检验身份证格式并输出出生日期,年龄,性别,出生地示例
May 17 Javascript
JS实现放烟花效果
Mar 10 Javascript
详解JavaScript 异步编程
Jul 13 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/25 PHP
特转载一高手总结PHP学习资源和链接.
2006/12/05 PHP
浅谈apache和nginx的rewrite的区别
2013/02/22 PHP
举例详解PHP脚本的测试方法
2015/08/05 PHP
微信开发之php表单微信中自动提交两次问题解决办法
2017/01/08 PHP
PHP的JSON封装、转变及输出操作示例
2019/09/27 PHP
如何在PHP中读写文件
2020/09/07 PHP
js获取多个tagname的节点数组
2013/09/22 Javascript
js 通过html()及text()方法获取并设置p标签的显示值
2014/05/14 Javascript
动态载入js提高网页打开速度的方法
2014/07/04 Javascript
JavaScript html5 canvas绘制时钟效果
2016/03/01 Javascript
angular ng-repeat数组中的数组实例
2017/02/18 Javascript
详解tween.js的使用教程
2017/09/14 Javascript
Ant Design Pro 下实现文件下载的实现代码
2019/12/03 Javascript
python之import机制详解
2014/07/03 Python
解决Python传递中文参数的问题
2015/08/04 Python
Python import与from import使用及区别介绍
2018/09/06 Python
python3实现从kafka获取数据,并解析为json格式,写入到mysql中
2019/12/23 Python
Python打包模块wheel的使用方法与将python包发布到PyPI的方法详解
2020/02/12 Python
详解使用python3.7配置开发钉钉群自定义机器人(2020年新版攻略)
2020/04/01 Python
python利用Excel读取和存储测试数据完成接口自动化教程
2020/04/30 Python
Python调用shell命令常用方法(4种)
2020/05/11 Python
Pyinstaller 打包发布经验总结
2020/06/02 Python
纯css3实现效果超级炫的checkbox复选框和radio单选框
2014/09/01 HTML / CSS
享誉全球的多元化时尚精品购物平台:Farfetch发发奇(支持中文)
2017/08/08 全球购物
Surfdome西班牙:世界上最受欢迎的生活方式品牌
2019/02/13 全球购物
哈萨克斯坦最大的时装、鞋子和配饰在线商店:Lamoda.kz
2019/11/19 全球购物
集团公司总经理岗位职责
2013/12/20 职场文书
交通安全标语
2014/06/06 职场文书
2014年物资管理工作总结
2014/12/02 职场文书
2014小学一年级班主任工作总结
2014/12/05 职场文书
2014年连锁店圣诞节活动方案
2014/12/09 职场文书
卫生院义诊活动总结
2015/05/07 职场文书
2015年车间管理工作总结
2015/07/23 职场文书
如何解决.cuda()加载用时很长的问题
2021/05/24 Python
JavaScript流程控制(循环)
2021/12/06 Javascript