用户
 找回密码
 立即注册

QQ登录

只需一步,快速开始

微客吧 首页 教程 微信小程序 实战教程 查看内容

微信小程序之换肤的功能

纸飞机 2018-3-19 18:34

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

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

由于微信

小程序

没有操作wxss的api,所以实现的方式有点不一样,大致如下:

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

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

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

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

例子:

第一步:结构

  1. <view class='page' id='{{SkinStyle}}'>
  2. <view class='header'>
  3. <view class='h-skin iconfont {{SkinStyle!=="normal"?"icon-moon":"icon-sun"}}' bindtap='bgBtn'></view>
  4. </view>
  5. </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:

  1. #dark {
  2. background: #333;
  3. }
  4. #dark .header .h-skin{
  5. color: white;
  6. }

正常wxss:

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

公用wxss:

  1. page {
  2. height: 100%;
  3. width: 100%;
  4. }
  5. .page {
  6. width: 100%;
  7. height: 100%;
  8. }

备注:这分别是三个文件。皮肤是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:

  1. var app=getApp();
  2. Page({
  3. data:{
  4. SkinStyle:"normal" //这里其实可以不要
  5. },
  6. bgBtn:function(){
  7. if (this.data.SkinStyle==="normal"){
  8. app.globalData.skin = "dark"; //设置app()中皮肤的类型
  9. this.setData({
  10. SkinStyle: app.globalData.skin //设置SkinStyle的值
  11. })
  12. wx.setStorage({ //设置storage
  13.      key: 'skins',
  14.      data: app.globalData.skin,
  15.    })
  16. }else{
  17. app.globalData.skin="normal";
  18. this.setData({
  19. SkinStyle: "normal"
  20. })
  21. wx.setStorage({
  22.      key: 'skins',
  23.      data: app.globalData.skin,
  24.    })
  25. }
  26. }
  27. })

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

  1. onLoad: function (options) {
  2. var that=this;
  3. wx.getStorage({
  4. key: 'skins',
  5. success: function(res) {
  6. that.setData({
  7. SkinStyle: res.data
  8. })
  9. },
  10. })
  11. }

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

最终效果图:

每天进步一点点。

鲜花
鲜花
握手
握手
雷人
雷人
路过
路过
鸡蛋
鸡蛋
分享至 : QQ空间
收藏