小程序页面动态配置实现

栏目: JavaScript · 发布时间: 7年前

内容简介:小程序可以根据管理后台配置动态更新展示内容,如实现下面新鲜事栏目图片的来源的可配置,点击跳转url的可配置。1后端创建一个map结构的数据表,表结构如下:2 管理后台根据不同业务设定不同的key和value,更新数据库

小程序可以根据管理后台配置动态更新展示内容,如实现下面新鲜事栏目图片的来源的可配置,点击跳转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(co
nfigList)});
......
复制代码

小程序

小程序调用后端接口返回所有配置项,具体业务根据具体业务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 前后端批量数据的传输问题;希望能给遇到同样问题的小伙伴一些启示,如果有更好的方案,欢迎一起讨论


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Algorithms Unlocked

Algorithms Unlocked

Thomas H. Cormen / The MIT Press / 2013-3-1 / USD 25.00

Have you ever wondered how your GPS can find the fastest way to your destination, selecting one route from seemingly countless possibilities in mere seconds? How your credit card account number is pro......一起来看看 《Algorithms Unlocked》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

SHA 加密
SHA 加密

SHA 加密工具

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换