微信小程序打包多主题方案

背景

曾经项目里遇到这样一个需求,最近回想起来想着把这个方案做一个记录。

由于我们的系统需要提供给多个租户方使用,系统的业务逻辑大体是相同的,并由一套小程序代码实现。而每个租户方希望得到的界面主题是不同的。这与在项目运行中切换主题不同,希望的是系统在发布后只有一个主题。

设计思路

  • 定义多个主题色class的样式

首先,我们需要定义多个主题class的样式,这些样式可以包括颜色、字体、背景等。由于本次需求的主题样式内容不多,因此我们将样式写在一份文件里,通过class区分。

css 复制代码
/* 红色主题 */
.red {
  /* 主色调RGB数值 */
  --R: 233;
  --G: 86;
  --B: 86;
  /* 全局主色  */
  --mainBgColor: #fb7059;
  /* 全局特殊副色  */
  --mainBgColor-Inactive: #f5b0b0;
  /* 其他色调 */
}

/* 金色主题 */
.golden {
  /* 主色调RGB数值 */
  --R: 201;
  --G: 159;
  --B: 90;
  /* 全局主色  */
  --mainBgColor: #c99f5a;
  /* 全局特殊副色  */
  --mainBgColor-Inactive: #e5bf80;
  /* 其他色调 */
}


/* 蓝色主题 */
.blue {
  /* 主色调RGB数值 */
  --R: 94;
  --G: 133;
  --B: 248;
  /* 全局主色  */
  --mainBgColor: #5E85F8;
  /* 全局特殊副色  */
  --mainBgColor-Inactive: #7a99f5;
  /* 其他色调 */
}
  • 配置主题标识与 键(appId)的关系

由于租户方和对应的主题是确定的,因此创建一个配置文件config.js,在配置文件中定义一个Map数据格式实现主题与appId的关系,并通过appId获取对应配置,导出配置模块供app.js引用。

javascript 复制代码
const configList = new Map([
  ['wx_appid1', {
    theme: 'red',
    // 其他配置
  }],
  ['wx_appid2', {
    theme: 'golden',
    // 其他配置
  }],
  ['wx_appid3', {
    theme: 'blue',
    // 其他配置
  }],
  // ...
])

const accountInfo = wx.getAccountInfoSync();
const appId = accountInfo.miniProgram.appId;
const config = configList.get(appId)
module.exports = {
  config
}

在 app.js 中引入此配置模块并设为globalData

javascript 复制代码
const config = require('/config');
App({
  globalData: {
    config
  }
})
  • 绑定页面class

在页面中,通过getApp().globalData获取全局数据,并拿到相关配置及主题标识。最终,将主题标识作为class绑定到页面元素中。

html 复制代码
<view class="{{theme}}"></view>

总结

通过以上步骤,我们实现了一个简单的微信小程序多主题方案。在实际开发中,可能还需要考虑主题切换的动画效果、主题的动态下载与更新等高级功能。但基本的思路是一致的:定义主题、配置主题、获取主题、应用主题。这样的设计可以让小程序更加灵活,满足多平台的个性化需求。

相关推荐
前端一课1 小时前
Vue3 的 Composition API 和 Options API 有哪些区别?举例说明 Composition API 的优势。
前端
用户47949283569151 小时前
都说node.js是事件驱动的,什么是事件驱动?
前端·node.js
晴殇i1 小时前
前端架构中的中间层设计:构建稳健可维护的组件体系
前端·面试·代码规范
申阳1 小时前
Day 7:05. 基于Nuxt开发博客项目-首页开发
前端·后端·程序员
Crystal3281 小时前
App端用户每日弹出签到弹窗如何实现?(uniapp+Vue)
前端·vue.js
摸着石头过河的石头1 小时前
Service Worker 深度解析:让你的 Web 应用离线也能飞
前端·javascript·性能优化
用户4099322502121 小时前
Vue 3中watch侦听器的正确使用姿势你掌握了吗?深度监听、与watchEffect的差异及常见报错解析
前端·ai编程·trae
1024小神1 小时前
Xcode 常用使用技巧说明,总有一个帮助你
前端
政采云技术2 小时前
音视频通用组件设计探索和应用
前端·音视频开发
Hilaku2 小时前
我用AI重构了一段500行的屎山代码,这是我的Prompt和思考过程
前端·javascript·架构