目前所在的公司做的是健康产业方面的APP,这个产品包括了安卓和IOS还有web三方面,除了要写后台管理的系统外,还要写移动端的接口。第一次写移动端接口就犯了一个错误,以为和web一样是怎么方便怎么来,然后和移动端人员对接的时候才知道为了程序的高效率最好是一个接口就能展示出整个页面的内容,而我原来写的代码确要移动端人员调用3个接口,查询数据库3次,效率低下。然后移动端人员给了以下数据展示需求:

展示hot热门音乐类型集合和recommend推荐音乐类型2个集合的数据,而recommend集合下又包含有music音乐集合的数据,即展示hotList和recommendList{musicList}中的数据。刚开始写的时候我是写一个接口分别通过字段hot和recommend查询hotList和recommendList2个集合的数据,然后另写一个接口查询musicList集合的数据。然后经过和移动端的同事交流和技术经理的指导后修改了接口代码如下:

    @RequestMapping(value = {"getHotRecommend"})
@ResponseBody
@RequiresUser(required = false)
public Result getHotRecommend() {
//获取热门或者推荐类型
List<MusicType> hotRecommendList = musicTypeService.selectHotList(); List<MusicType> recommendList = new ArrayList<MusicType>(); //新建推荐list
List<MusicType> hotList = new ArrayList<MusicType>(); //新建热门list List<MusicType> resultList = new ArrayList<MusicType>(); if(CollectionUtil.isNotEmpty(hotRecommendList)){
for(MusicType musicType : hotRecommendList){ if(musicType.getRecommend() == 1){
recommendList.add(musicType);
} if(musicType.getHot() == 1){
hotList.add(musicType);
} }
}
if(CollectionUtil.isNotEmpty(recommendList)){
for(MusicType m : recommendList){
//拿到id,获取音乐list
List<HealthMusic> list = healthMusicService.findMusicListByRecommend(m.getId());
m.setMusicList(list);
resultList.add(m);
}
} Map map = new HashMap();
map.put("hotList",hotList);
map.put("recommendList",resultList);
return Result.successResult().setObj(map);
}

一次查询出hotList和recommendList集合中的数据,经过一次循环把hotList和recommendList分开,比原来少了一次对数据库的骚扰,多了一次循环,在数据量不大的循环效率比较高,至于查询音乐musicList和原来写的差不多,至于更好的写法、更好的优化可以慢慢探讨。

一个APP页面一个接口的更多相关文章

  1. 教你判断一个APP页面是原生的还是H5页面 。(还没看)

    来源:https://www.25xt.com/appdesign/11851.html 刚好是周末,无意之间学堂君在收集相关资料的时候,发现有部分童鞋在问<如何判断一个APP页面是不是H5页面 ...

  2. 12小时包你学会基于ReactMix框架的ReactNativeApp开发(二)基于Css+HTML写第一个app页面

    上一篇文章,大家对于ReactMix(https://github.com/xueduany/react-mix)框架有了一个基本认识,知道我们是一个语法糖,帮助大家基于一套代码,所有平台都能跑.那么 ...

  3. 如何判断一个 APP页面是否是H5页面

    1.无网络断开网络,显示404或则错误页面的是H5 2.页面布局a.在手机设置.开发者选项中开启显示布局边界功能:b.进入应用查看布局边界:c.原生应用可以看到各个控件的布局边界,H5只有整个页面的一 ...

  4. 如何判断一个 APP页面是否是H5页面(转载)

    1.无网络断开网络,显示404或则错误页面的是H5 2.页面布局a.在手机设置.开发者选项中开启显示布局边界功能:b.进入应用查看布局边界:c.原生应用可以看到各个控件的布局边界,H5只有整个页面的一 ...

  5. 用weexplus从0到1写一个app(2)-页面跳转和文章列表及文章详情的编写

    说明 结束连续几天的加班,最近的项目终于告一段落,今天抽点时间开始继续写我这篇拖了很久的<用weexplus从0到1写一个app>系列文章.写这篇文章的时候,weexplus的作者已经把w ...

  6. 一个App完成入门篇(五)- 完成新闻页面

    本节教程将介绍如何用DeviceOne简单而高效的完成一个新闻页面. 导入项目 数据模板分离MVVM模型 自定义事件 展示新闻 九宫格展示 将要学习的demo效果图如下所示 1. 导入完整项目 本节示 ...

  7. 为Go Web App 创建一个主页面

    原文地址    大多数web app都有一个相同的布局.这个布局可能包含一个header或者footer,甚至可能包含一个导航菜单.Go的标准库提供一个简单的方式来创建这些基本元素,通过被不同的页面重 ...

  8. 我的第一个python web开发框架(18)——前台页面与接口整合

    由于我们前后台系统没有分开,所以前台页面调用接口时,可以直接使用后台管理系统已经完成的接口,不过后台管理系统接口的访问加上了登录验证,所以需要将前台要用到的接口进行处理,让它们设置到白名单当中 我们打 ...

  9. android一个app打开另一个app的指定页面

    一个app打开另一个app的指定页面方法 有以下几种 1.通过包名.类名 2.通过intent的 action 3.通过Url 方案1. ComponentName componentName = n ...

随机推荐

  1. iis7 部署网站 403错误

    C:\Windows\Microsoft.NET\Framework\v4.0.30319\aspnet_regiis.exe -i 403 - 禁止访问: 访问被拒绝. 您无权使用所提供的凭据查看此 ...

  2. ASP.NET中HttpContext.Cache的使用

    -------------------------------键 --值-----依赖-----过期时间-------------------------------绝对过期------------- ...

  3. Unity3D_GUI (1)--按钮控件

    这是自己的第一篇记录自己的技术文章,自己还是个菜鸟,有错误之处还望大家能够多多指点. 下面记录的是自己在学GUI.Button的自己认知,这里用的是代码进行控制,当然当你学熟练了就可以直接使用GUI ...

  4. Python入门 - 时间处理

    本讲主要介绍python时间处理方式,比如获取当前的时间: import time ftime = time.strftime("%Y年%m月%d日%H点%M分%S秒", time ...

  5. 用python 抓取B站视频评论,制作词云

    python 作为爬虫利器,与其有很多强大的第三方库是分不开的,今天说的爬取B站的视频评论,其实重点在分析得到的评论化作嵌套的字典,在其中取出想要的内容.层层嵌套,眼花缭乱,分析时应细致!步骤分为以下 ...

  6. 51Nod 1267 4个数和为0 二分

    给出N个整数,你来判断一下是否能够选出4个数,他们的和为0,可以则输出"Yes",否则输出"No".Input第1行,1个数N,N为数组的长度(4 <= ...

  7. HDU5804--Price List

    Price List Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 262144/131072 K (Java/Others) Tot ...

  8. php提供的对称加密算法

    KEY 是之前定义的常量 Mcrypt::encrypt(); Mcrypt::decrypt(); defined('ROOT') or exit('Access Denied'); class M ...

  9. CentOS7 nginx简单配置pathinfo模式(ThinkPHP)

    location ~ \.php {    #去掉$ root          H:/PHPServer/WWW; fastcgi_pass   127.0.0.1:9000; fastcgi_in ...

  10. ssm开发使用redis作为缓存,使用步骤

    1.关于spring配置文件中对于redis的配置 <!-- redis配置 --> <bean id="jedisPoolConfig" class=" ...