国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

微信小程序實現換膚功能

2019-11-19 14:10:11
字體:
來源:轉載
供稿:網友

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

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

最終效果圖:

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 石河子市| 芮城县| 齐齐哈尔市| 新乡市| 丰顺县| 东兰县| 宁津县| 武穴市| 高清| 寿光市| 龙川县| 响水县| 且末县| 习水县| 德兴市| 屯留县| 南部县| 五河县| 巧家县| 乐安县| 高雄县| 临泉县| 裕民县| 米林县| 彩票| 罗城| 赤城县| 泰安市| 克什克腾旗| 云梦县| 东宁县| 普宁市| 灌云县| 庆阳市| 儋州市| 马公市| 黔西| 会东县| 鲁甸县| 铜梁县| 开平市|