微信小程序如何实现切换主题(更改皮肤)

一:基本原理
因为小程序中没有样式引入的概念,所以不能像传统的html中那样改变link标签的href值来达到切换样式文件。
在小程序中,可以在类名中定义变量,通过动态改边类名,最终达到修改样式的目的。

二:具体实现

在wxml文件中:
其中的变量theme来自welcome.js中,theme的值决定着使用哪个样式来影响页面
在这里插入图片描述

在wxss文件中:
这里需要把所有的样式文件都引入进来,因为小程序里不能像htnml中那样改边link标签的动态切换href值。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
举例:例如在welcome.js中theme的值为blue,那么在上图wxml中view的类名最终为content-blue,
因此welcome-blue中的样式就会生效。其他样式文件的则不会生效。
最终实现了主题切换

三 总结

在实现小程序主题切换的时候,需要把当前页面的所有的样式文件都引入进来。我们也可以把这些样式文件写在一个wxss文件中,不过那样样式不太好区分,后期维护会有困难。

缺点:
在wxml中使用变量的方式编写页面,会增加开发时间。

另外,在小程序中组件只能继承页面的字体,背景等极少数的样式,如果添加主题切换功能,需要在每个组件在其内部重新书写一套样式,会增加组件的开发时间。

  • 5
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值