时间:2021-05-18
小程序可以根据管理后台配置动态更新展示内容,如实现下面新鲜事栏目图片的来源的可配置,点击跳转url的可配置。
实现方案
1后端创建一个map结构的数据表,表结构如下:
2 管理后台根据不同业务设定不同的key和value,更新数据库
如key:ad1url value:a.png
如果需要更新页面图片,只需更新ad1url对应的value
3 小程序根据对应业务key获取对应的配置项,更新页面显示
技术栈
后端接口服务:SpringBoot Mybatis MySql
管理后台:vue
前端:小程序
代码实现
后端接口
为了保证key的唯一性,key在数据库设置为unique属性,新增和更新功能通过以下sql语句实现,主要通过replace into实现配置项的唯一
@Insert("<script>" + "REPLACE INTO `rental`.`t_config`(`key`, `value`) VALUES" + "<foreach" + " collection=\"list\" item=\"item1\" index=\"index\" separator=\",\">" + "(#{item1.key}, #{item1.value})" + "</foreach>" + "</script>") @Options(useGeneratedKeys = true, keyProperty = "configId", keyColumn = "configId")api设计
一开始想通过传如list数据给后端实现配置项的批量插入功能,发现后端数据一直接受不到,故而退而求其次,通过json字符串实现vue(网络库使用axios)调用后端接口
@ApiOperation(value = "新增或更新配置列表")@RequestMapping(value = "/add_or_update_config_list", method = RequestMethod.POST, produces = MediaType.APPLICATION_JSON_UTF8_VALUE)public ResponseBean<String> addOrUpdateConfigList(String list) { long result = configService.batchInsertOrUpdate(JSONObject.parseArray( list,Config.class)); ......}管理平台
管理平台用vue开发,网络框架采用axios,列表数据通过json字符串传递给后端
let config1 = {key: "ad1Url", value: this.formData.ad1Url};let config2 = {key: "ad2Url", value: this.formData.ad2Url};let config3 = {key: "adClick1", value: this.formData.adClick1};let config4 = {key: "adClick2", value: this.formData.adClick2};let configList = [config1, config2, config3, config4];let result = await addConfigList({list: JSON.stringify(configList)});......小程序
小程序调用后端接口返回所有配置项,具体业务根据具体业务key获取配置项
getConfigList: function () { var that = this; wx.request({ url: constant.HOST + '/config/get_config_list', method: 'GET', header: { 'content-type': 'application/json' }, complete: function (res) { }, success: function (res) { console.log("config list response:" + JSON.stringify(res)); that.setData({ configList: res.data.data}); } }); }, goAd1: function(){ wx.navigateTo({ url: '/pages/webview/webview?url=' + this.data.configList.adClick1 })},总结
这个功能我在自己的小程序开发过程中设计的页面配置实现思路,主要遇到了两个小问题:1 如果保证key的唯一性 2 前后端批量数据的传输问题;希望能给遇到同样问题的小伙伴一些启示,如果有更好的方案,欢迎一起讨论
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
微信小程序配置顶部导航条标题颜色的实现方法关于小程序导航顶部配置都写在.json文件中。{"window":{"navigationBarBackgroundC
本文实例讲述了微信小程序实现动态设置页面标题的方法。分享给大家供大家参考,具体如下:1、效果展示2、关键代码①WXML文件标题1标题2标题3还原②JS文件Pag
本文实例讲述了微信小程序实现动态获取元素宽高的方法。分享给大家供大家参考,具体如下:我以前一直以为微信小程序不能动态获取view元素的宽高。但是自从看到:wx.
微信小程序——配置以下就是小编对小程序配置的资料进行的系统的整理,希望能对开发者有帮助。我们使用app.json文件来对微信小程序进行全局配置,决定页面文件的路
本文实例讲述了C#实现在控制台输出当前系统时间的方法。分享给大家供大家参考。具体实现方法如下://C#实现的小控制台程序:动态输出当前时间usingSystem