首頁 >web前端 >js教程 >微信小程式實現換膚功能

微信小程式實現換膚功能

亚连
亚连原創
2018-05-30 10:54:582309瀏覽

這篇文章主要為大家詳細介紹了微信小程式實現換膚功能,具有一定的參考價值,有興趣的朋友們可以參考一下

pc或者移動端實現換膚功能還是比較簡單的,大致就是需要換膚的css,還有正常的css;把當前皮膚類型存入本地;然後通過js讀取並判斷當前應該加載哪套css。

由於微信小程式沒有操作wxss的api,所以實現的方式有點不一樣,大致如下:

  1.需要換膚的wxss,正常的wxss。

  2.每個頁面都引入換膚的wxss(因為換膚每個頁面都需要改變)。

  3.在app.js的globalData裡設定預設的皮膚類型。

  4.每個頁面onload的時候,讀取storage裡的資料並設定目前皮膚類型的值。

範例:

第一步:結構

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

備註:由於無法直接操作微信小程式的根節點page,要實作全螢幕背景色的修改,只能模仿一個高度寬度都是100%的p(觀點)。上面就是class為page的這個p(view)。

   id='{{SkinStyle}}',設定id是為了根據當前皮膚類型,讓皮膚的wxss樣式的權重大於正常wxss樣式的權重,這樣有時候就沒必要加上! important了。

   根節點page需要在wxss中設定width:100%;height:100%。然後設定class為page的p(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: &#39;skins&#39;,
       data: app.globalData.skin,
     })
  }else{
   app.globalData.skin="normal";
   this.setData({
    SkinStyle: "normal"
   })
   wx.setStorage({
       key: &#39;skins&#39;,
       data: app.globalData.skin,
     })   
  }  
 }
})

最後:在每個頁面,包括切換皮膚的頁面的Page中的onLoad事件裡,讀取storage並設定SkinStyle的值:

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

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

最終效果圖:

上面是我整理給大家的,希望今後會對大家有幫助。

相關文章:

js中apply和Math.max()函數的問題及區別介紹

淺談Vue內建component元件的應用場景

vue2中使用less簡易教學

#

以上是微信小程式實現換膚功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn