微信小程序换肤功能实现方法详细步骤与探讨

why 34 2024-09-30

pc或者移动端实现换肤功能还是比较简单的,大致就是需要换肤的css,还有正常的css;把当前皮肤类型存入本地;然后通过js读取并判断当前应该加载哪套css。本文主要和大家详细介绍了微信小程序实现换肤功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能帮助到大家。

由于微信小程序没有操作wxss的api,所以实现的方式有点不一样,大致如下:

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

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

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

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

例子:

第一步:结构


1

2

3

4

5

<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(view)。上面就是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:


1

2

3

4

5

6

#dark {

 background: #333;

}

#dark .header .h-skin{

 color: white;

}

正常wxss:


1

2

3

4

5

.page .header .h-skin {

 color: #060505;

 padding: 0 32rpx;

 font-size: 40rpx;

}

公用wxss:


1

2

3

4

5

6

7

8

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:


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

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的值:


1

2

3

4

5

6

7

8

9

10

11

onLoad: function (options) {

 var that=this;

 wx.getStorage({

 key: &#39;skins&#39;,

 success: function(res) {

  that.setData({

   SkinStyle: res.data

  })

 },

 })

}

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

最终效果图:


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:企业转账到用户接口开通步骤详细介绍与解析
下一篇:微信小程序 js 文件外部引用实例详细解析与展示
相关文章

 发表评论

暂时没有评论,来抢沙发吧~