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({         //设置storagekey: '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})},})
}

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

最终效果图:

转载于:https://www.cnblogs.com/zjjDaily/p/8565732.html

微信小程序之换肤的功能相关推荐

  1. 微信小程序 实现换肤功能

    参考链接: (1)微信小程序实现换肤功能 https://www.jb51.net/article/136445.htm (2)微信小程序实现换肤功能 https://blog.csdn.net/qq ...

  2. 小程序服务器换肤,微信小程序实现换肤功能

    pc或者移动端实现换肤功能还是比较简单的,大致就是需要换肤的css,还有正常的css:把当前皮肤类型存入本地:然后通过js读取并判断当前应该加载哪套css. 由于微信小程序没有操作wxss的api,所 ...

  3. 为微信小程序增加换肤功能

    起源 之前,我做了一个展示类的微信小程序,本来都快要完结的了,可是突然,我才听说还要给小程序增加一个换肤功能,这个换肤功能可不是简单的写两套不同的样式表就行了,因为他要可以在后台动态替换背景,底图,文 ...

  4. 微信小程序实现换肤功能

    在手机.电脑使用频率如此高的当下,应用可以更换皮肤,以提升美观性,并减轻屏幕对眼睛的刺激,无疑对用户体验有很大的帮助 实现功能 要实现如上更换皮肤的效果,有几个思路: 1.准备皮肤相关的wxss,引入 ...

  5. 怎么实现微信小程序云开发拼团功能?

    [微信云开发教程]怎么实现微信小程序云开发拼团功能? 提示:这里可以添加系列文章的所有文章的目录,目录需要自己手动添加 提示:写完文章后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 [微 ...

  6. 微信小程序 - 实现左滑动删除功能

    微信小程序 - 实现左滑动删除功能 效果图: 实现过程: 一.wxml布局 这里我是先用了一个大盒子包裹小盒子,然后小盒子里面进行左右布局(左边为内容部分,右边为删除按钮)的方式实现的 <vie ...

  7. 微信小程序购物车 数量加减功能

    微信小程序购物车 数量加减功能 wxml <!-- 主容器 --> <view class="stepper"> <!-- 减号 --> < ...

  8. 微信小程序的搜索和重置功能

    微信小程序的搜索和重置功能 wxml <template><div><div class="input-wrap"><el-inputse ...

  9. 基于微信小程序的用户列表点赞功能

    代码地址如下: http://www.demodashi.com/demo/13997.html 一.前言 (1).适合人群 1.微信小程序开发者 2.前端工程师 3.想入门学习小程序开发的人员 4. ...

最新文章

  1. 自动化办公之excel教程(8):单变量求解,规划求解,页面布局,打印设置
  2. [原]浅谈几种服务器端模型——反应堆模式(epoll 简介) - _Boz - 博客园
  3. Win2008使用WEB方式更改工作组计算机用户帐户密码
  4. shell中if条件字符串、数字比对,` `和[ ]区别
  5. python深度学习机器学习必备的学习网站集合!
  6. 万里牛B轮融资过亿,电商SaaS究竟有多吸金?
  7. 网站优化快速排名软件大全
  8. ICT通信运营企业的重建之服务升级(三)----如何打造ICT服务满意度
  9. linux上的smartsvn图形客户端,CentOS6.3下svn图形客户端smartsvn安装
  10. 国内Docker镜像加速汇总
  11. chrome开发者工具实现网页截长图
  12. Lee滤波和Refine-Lee滤波
  13. 《给李彦宏先生的一封信》
  14. 堆叠柱状图加上折线图-echart图表(一)
  15. oracle表如何做统计分析,Oracle表统计信息的分析
  16. HTMLCSSHTTP
  17. xp计算机无法远程桌面连接,XP sp3系统下远程桌面不能连接到指定计算机的解决方案...
  18. 给安卓手机里的Firefox安装AdGuard的https过滤证书
  19. java全栈系列之JavaSE--Arrays类详解027
  20. Linux中的pushd和popd

热门文章

  1. Appium 夜神 配置
  2. 百度快照被劫持跳转到博彩页面的解决办法
  3. Android 实现圆角布局,变相实现圆角图片效果(不同位置不同弧度)
  4. Systrace的用法小结
  5. preg_match_all中的标记
  6. 2009年存储市场10大预测 厂商并购在所难免
  7. 编程之美2——N!的二进制表示中最低位1的位置
  8. 利用Glibc库-ORIGIN-提权
  9. 基于.net载发软件的下拉框(ComBox)无法显示数据问题
  10. 在Linux系统环境下修改MySQL的root密码