Uniapp项目自定义主题

需求描述

在进行部分手机软件开发过程中,可能会出现需要设计手机主题的状况,最为典型的就是手机游览器提供的黑夜模式与白天模式,需要指出的是uniapp官方提供了darkMode即暗黑主题的插件的,但是在我实际开发中出现了无法在项目中正常使用该插件的状况,所以我们这时候就需要自己来搞一个主题了

设计方案

1.首先在当前项目中创建一个theme文件夹,用来存放我们的自定义主题

2.接着创建一个主题的样式文件,如theme.css/theme.less/theme.sass

3.接着我们在该文件中根据你所使用的样式语言来编写主题样式,例如:

.dark{
	background-color:#1f1f1f;
	color:#ccc;
}

.light{
	background-color: aliceblue;
	color:black;
}

4.回到我们的view组件中,在style样式区导入该主题样式文件,例如:

<style lange=”less” scoped>
	@import '../../theme/theme.less';
	//其他样式照写不误
</style>

5.在template区中我们可以定义一个view 或者直接在当前组件的父view上直接配置动态class

	<view class="content" :class="theme=='dark'?'dark':'light'">
		<topCompontent></topCompontent>
	</view>

6.在script区域定义一个控制主题类别的变量,当然了这个变量可以存放在本地缓存中或者其他你认为合适的地方,总之我们需要一个变量来控制主题

const theme=ref(‘light’);

最后,我们只需要对该变量进行数据操控就可以进行主题切换了,至此一个自定义主题就算是初步完成了

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值