91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

小程序頁面動態配置實現方法

發布時間:2020-09-19 10:16:02 來源:腳本之家 閱讀:277 作者:worldant 欄目:web開發

小程序可以根據管理后臺配置動態更新展示內容,如實現下面新鮮事欄目圖片的來源的可配置,點擊跳轉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 前后端批量數據的傳輸問題;希望能給遇到同樣問題的小伙伴一些啟示,如果有更好的方案,歡迎一起討論

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

望城县| 闽侯县| 永昌县| 桑日县| 南投县| 吕梁市| 拜泉县| 庆云县| 营口市| 东乌珠穆沁旗| 镇平县| 阳春市| 崇阳县| 浦东新区| 焉耆| 施甸县| 林口县| 毕节市| 启东市| 三门县| 九寨沟县| 永吉县| 内乡县| 罗江县| 铁岭市| 吉安县| 盐边县| 潮州市| 云霄县| 陇西县| 桐乡市| 九台市| 花莲市| 喀喇| 巴里| 兴和县| 景洪市| 德庆县| 紫云| 临武县| 桦南县|