微信小程序之換膚的功能


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
        })
    },
  })
}

 這樣每次啟動都能自動設置上一次設置的皮膚 了

最終效果圖:

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM