最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

微信小程序实现换肤功能

来源:动视网 责编:小OO 时间:2020-11-27 19:44:00
文档

微信小程序实现换肤功能

pc或者移动端实现换肤功能还是比较简单的,大致就是需要换肤的css,还有正常的css;把当前皮肤类型存入本地;然后通过js读取并判断当前应该加载哪套css。由于微信小程序没有操作wxss的api,所以实现的方式有点不一样,大致如下:1.需要换肤的wxss,正常的wxss。2.每个页面都引入换肤的wxss(因为换肤每个页面都需要改变)。3.在app.js的globalData里设置默认的皮肤类型。4.每个页面onload的时候,读取storage里的数据并设置当前皮肤类型的值。例子。第一步:结构;
推荐度:
导读pc或者移动端实现换肤功能还是比较简单的,大致就是需要换肤的css,还有正常的css;把当前皮肤类型存入本地;然后通过js读取并判断当前应该加载哪套css。由于微信小程序没有操作wxss的api,所以实现的方式有点不一样,大致如下:1.需要换肤的wxss,正常的wxss。2.每个页面都引入换肤的wxss(因为换肤每个页面都需要改变)。3.在app.js的globalData里设置默认的皮肤类型。4.每个页面onload的时候,读取storage里的数据并设置当前皮肤类型的值。例子。第一步:结构;
 这篇文章主要为大家详细介绍了微信小程序实现换肤功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

#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:

最后:在每个页面,包括切换皮肤的页面的Page中的onLoad事件里,读取storage并设置SkinStyle的值:

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

最终效果图:

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

js中apply和Math.max()函数的问题及区别介绍

浅谈Vue内置component组件的应用场景

vue2中使用less简易教程

文档

微信小程序实现换肤功能

pc或者移动端实现换肤功能还是比较简单的,大致就是需要换肤的css,还有正常的css;把当前皮肤类型存入本地;然后通过js读取并判断当前应该加载哪套css。由于微信小程序没有操作wxss的api,所以实现的方式有点不一样,大致如下:1.需要换肤的wxss,正常的wxss。2.每个页面都引入换肤的wxss(因为换肤每个页面都需要改变)。3.在app.js的globalData里设置默认的皮肤类型。4.每个页面onload的时候,读取storage里的数据并设置当前皮肤类型的值。例子。第一步:结构;
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top