需求背景
我正在用 golang + react ant design pro 开发一套公司内部使用的物联网产品解决方案的介绍网站,同时支持电脑端和手机端。
但是突然来了一个客户的紧急需求,就是能够手机扫描二维码,直接查看产品介绍。 最初想做微信小程序,但是由于要兼容海外市场,最终决定采用 H5 页面的方式来实现,支持中英双语。
于是纠结来了。如果把现在正在开发的那套代码复制过来,很多地方都是需要调整的,例如:
- 公司 logo
- 企业名称
- 备案号
等。而这些模板修改,放到代码中,非常不方便维护,以后再有第三套,第四套同样需要这些修改。
于是,我想是否能够实现一套像 php wordpress 那样的通用网站架构。
这样,多套主题模板就能复用了,而且只要数据库不共享,也不会泄露不通过站点之间的业务数据。
可以抽象出来的共性配置
- 公司 logo
- 企业名称
- 备案号
- 联系电话。可以多个
- 企业简介
- banners。可以添加描述,及跳转链接
- 多语言设置
不同公司、业务模板的实现方案
参考 wordpress 的实现方案,在项目根目录下设置一个主题目录 themes,里面包含一堆主题模板。
在单个主题目录内,再实现具体的首页,详情页模板。
但也需要一些规范:
- 模板可以在后台管理页面选择配置; 加载模板时,从数据库读取配置
- 模板文件遵守命名规范。例如:index.html, detail.html
- 每个模板使用一个 css 文件
- js 文件也使用一个,即便用到多个,后台构建时,打包成一个,并做混淆
- 支持自定义 css 的配置,存数据库中,也是参考 wp 的做法。使用场景,例如,顶部 logo 的尺寸不同,需要使用不同的宽高限制。
采用的技术方案
- 后台 golang。实在接受不了 PHP 的性能,及多版本部署的麻烦
- 管理后台,做前后端分离,使用 React Ant Design Pro V5
- 模板直接用 golang template。目前看够用
- CSS 使用 Tailwind CSS 构建
- 图片传七牛 CDN 存储并加速