微信小程式實現換膚功能,微信小程式換膚

來源:互聯網
上載者:User

小程式實現換膚功能,小程式換膚

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

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

最終:

以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支援幫客之家。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.