微信小程序实现换肤功能


Posted in Javascript onMarch 14, 2018

pc或者移动端实现换肤功能还是比较简单的,大致就是需要换肤的css,还有正常的css;把当前皮肤类型存入本地;然后通过js读取并判断当前应该加载哪套css。

由于微信小程序没有操作wxss的api,所以实现的方式有点不一样,大致如下:

1.需要换肤的wxss,正常的wxss。

2.每个页面都引入换肤的wxss(因为换肤每个页面都需要改变)。

3.在app.js的globalData里设置默认的皮肤类型。

4.每个页面onload的时候,读取storage里的数据并设置当前皮肤类型的值。

例子:

第一步:结构

<view class='page' id='{{SkinStyle}}'>
 <view class='header'>
  <view class='h-skin iconfont {{SkinStyle!=="normal"?"icon-moon":"icon-sun"}}' bindtap='bgBtn'></view>  
 </view>
</view>

备注:由于不能直接操作微信小程序的根节点page,要实现全屏背景色的修改,只能模仿一个高度宽度都是100%的div(view)。上面就是class为page的这个div(view)。

 id='{{SkinStyle}}',设置id是为了根据当前皮肤类型,让皮肤的wxss样式的权重大于正常wxss样式的权重,这样有时候就没必要加上!important了。

 根节点page需要在wxss中设置width:100%;height:100%。然后设置class为page的div(view)宽高都是100%。这样就相当于有个能操作的根节点page了。

 {{SkinStyle!=="normal"?"icon-moon":"icon-sun"}}这句是判断当前的皮肤类型,如果是normal就是icon-sun,否则就是icon-moon。 

第二步:样式wxss

皮肤wxss:

#dark {
 background: #333;
}
#dark .header .h-skin{
 color: white;
}

正常wxss:

.page .header .h-skin {
 color: #060505;
 padding: 0 32rpx;
 font-size: 40rpx;
}

 公用wxss:

page {
 height: 100%;
 width: 100%;
}
.page {
 width: 100%;
 height: 100%;
}

备注:这分别是三个文件。皮肤是theme.wxss,正常是index.wxss,公用是com.wxss

 因为换肤是所有页面都变化,所以我建议把皮肤的wxss文件 @import "../theme-bg/theme";  加载到com.wxss文件中。然后每个页面的wxss都@import这个公用的com.wxss文件。

第三步:js

首先:在app.js的文件中,Page里的globalData中设置:skin:"normal";即默认为normal皮肤

然后:在切换皮肤按钮的页面,添加切换按钮的点击事件bgBtn:

var app=getApp();
Page({
 data:{
   SkinStyle:"normal"  //这里其实可以不要
 }, 
 bgBtn:function(){
  if (this.data.SkinStyle==="normal"){
   app.globalData.skin = "dark"; //设置app()中皮肤的类型
   this.setData({
    SkinStyle: app.globalData.skin //设置SkinStyle的值
   })
   wx.setStorage({   //设置storage
   
key: 'skins',
  
 
data: app.globalData.skin,
  
 })
  }else{
   app.globalData.skin="normal";
   this.setData({
    SkinStyle: "normal"
   })
   wx.setStorage({
  
 
key: 'skins',
  
 
data: app.globalData.skin,
  
 })   
  }  
 }
})

最后:在每个页面,包括切换皮肤的页面的Page中的onLoad事件里,读取storage并设置SkinStyle的值:

onLoad: function (options) { 
 var that=this;
 wx.getStorage({
 key: 'skins',
 success: function(res) {
  that.setData({
   SkinStyle: res.data
  })
 },
 })
}

这样每次启动都能自动设置上一次设置的皮肤了。

最终效果图:

微信小程序实现换肤功能

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
腾讯UED 漂亮的提示信息效果代码
Sep 12 Javascript
详细介绍8款超实用JavaScript框架
Oct 25 Javascript
使用js完成节点的增删改复制等的操作
Jan 02 Javascript
Javascript实现Web颜色值转换
Feb 05 Javascript
jQuery实现仿QQ空间装扮预览图片的鼠标提示效果代码
Oct 30 Javascript
AngularJS基础 ng-cut 指令介绍及简单示例
Aug 01 Javascript
JavaScript重定向URL参数的两种方法小结
Oct 19 Javascript
Vue2.0 slot分发内容与props验证的方法
Dec 12 Javascript
Node.js搭建小程序后台服务
Jan 03 Javascript
Vue 与 Vuex 的第一次接触遇到的坑
Aug 16 Javascript
node.js使用yargs处理命令行参数操作示例
Feb 11 Javascript
解决vue动态路由异步加载import组件,加载不到module的问题
Jul 26 Javascript
Angular4集成ng2-file-upload的上传组件
Mar 14 #Javascript
iview table高度动态设置方法
Mar 14 #Javascript
vue2.0安装style/css loader的方法
Mar 14 #Javascript
Vue2.0 事件的广播与接收(观察者模式)
Mar 14 #Javascript
vue项目国际化vue-i18n的安装使用教程
Mar 14 #Javascript
Vue使用mixins实现压缩图片代码
Mar 14 #Javascript
vue2.0模拟锚点的实例
Mar 14 #Javascript
You might like
一个简单的PHP投票程序源码
2007/03/11 PHP
PHP使用正则表达式获取微博中的话题和对象名
2015/07/18 PHP
CI框架表单验证实例详解
2016/11/21 PHP
使用PHPWord生成word文档的方法详解
2019/06/06 PHP
图片无缝滚动代码(向左/向下/向上)
2013/04/10 Javascript
JavaScript jquery及AJAX小结
2016/01/24 Javascript
JS传值出现中文参数乱码的解决方法
2016/06/30 Javascript
微信小程序 常见问题总结(4058,40013)及解决办法
2017/01/11 Javascript
详谈JavaScript的闭包及应用
2017/01/17 Javascript
JavaScript下拉菜单功能实例代码
2017/03/01 Javascript
JS实现双击内容变为可编辑状态
2017/03/03 Javascript
基于vue2的table分页组件实现方法
2017/03/20 Javascript
详解基于vue的移动web app页面缓存解决方案
2017/08/03 Javascript
JS跨域请求的问题解析
2018/12/03 Javascript
JavaScript数据结构与算法之检索算法实例分析【顺序查找、最大最小值、自组织查询】
2019/02/22 Javascript
js实现简单图片拖拽效果
2021/02/22 Javascript
[03:07]2015国际邀请赛选手档案EHOME.rOtK 是什么让他落泪?
2015/07/31 DOTA
python搜索指定目录的方法
2015/04/29 Python
Python中函数的参数传递与可变长参数介绍
2015/06/30 Python
Python实现求解一元二次方程的方法示例
2018/06/20 Python
Flask之flask-script模块使用
2018/07/26 Python
浅析python3字符串格式化format()函数的简单用法
2018/12/07 Python
对Python生成器、装饰器、递归的使用详解
2019/07/19 Python
django认证系统 Authentication使用详解
2019/07/22 Python
Tensorflow Summary用法学习笔记
2020/01/10 Python
opencv中图像叠加/图像融合/按位操作的实现
2020/04/01 Python
完美解决Django2.0中models下的ForeignKey()问题
2020/05/19 Python
python实现三壶谜题的示例详解
2020/11/02 Python
解决Pymongo insert时会自动添加_id的问题
2020/12/05 Python
Html5原创俄罗斯方块(基于canvas)
2019/01/07 HTML / CSS
美国生日蛋糕店:Bake Me A Wish!
2017/02/08 全球购物
Lookfantastic葡萄牙官方网站:欧洲第一大化妆品零售商
2018/03/17 全球购物
酒店秘书求职信范文
2014/02/17 职场文书
学习党代会心得体会
2014/09/05 职场文书
2019中小学生安全过暑期倡议书
2019/06/24 职场文书
《地。-关于地球的运动-》单行本第七集上市,小说家朝井辽献上期待又害怕的推荐文
2022/03/31 日漫