如何用一个接口优雅的实现2个List的翻页加载

简介: 如何用一个接口实现2个list的翻页加载,需求如下图所示,当list1数据全部加载完毕之后再返回list2的数据。

首先抛出我的问题?


如何用一个接口实现2个list的翻页加载,需求如下图所示,当list1数据全部加载完毕之后再返回list2的数据。(不限制list1和list2的数据个数,有多少条都要通过翻页加载取出来)


思路


  1. 关键问题是如何定义翻页,什么场景下开始返回list2的数据
  2. 翻页加载标配字段pageCount,来定义每页加载数量
  3. track定义翻页规则,用|分割,|前面是偏移量,|后面标记本次返回哪个list的数据
  4. 将list1和list2对应的返回场景定义为常量,方便区分


核心代码


const TYPE_LIST1 = 1; 
    const TYPE_LIST2 = 2;
        public static function demoList($userid, $pageCount = 10, $track = '', $select = '*')
    {
        $offsetTrack = 0;
        $typeTrack = 1;
        $more = 1;
        $list1 = [];
        $list2 = [];
        if (!empty($track)) {
            $decodeTrack = explode("|", $track);
            $offsetTrack = intval($decodeTrack[0]);
            $typeTrack = intval($decodeTrack[1]);
        }
        //取list1 或者 list1+list2
        if ($typeTrack == self::TYPE_LIST1) {
            $list1 = self::getList1($userid, $offsetTrack, $pageCount);
            //list1返回的个数比pageCount小 说明数据不足 需要在请求list2的数据
            $list1Count = count($list1);
            if ($list1Count < $pageCount) {
                $typeTrack = self::TYPE_LIST2;
                $offsetTrack = $list1Count;
            } else {
                $track = $offsetTrack + $list1Count . "|" . self::TYPE_LIST1;
                $more = 1;
            }
        }
        //只取list2
        if ($typeTrack == self::TYPE_LIST2) {
            $offset = $offsetTrack;
            $list2 = self::getList2($userid, $pageCount, $offset);
            $more = count($list2) < $pageCount ? 0 : 1;
            $track = $offset + count($list2) . "|" . self::TYPE_LIST2;
        }
        $ret = [
            'track' => $track,
            'more' => $more,
            'list1' => $list1,
            'list2' => $list2,
        ];
        return $ret;
    }
复制代码


进阶思路


  1. 上面代码简化了getList1(),getList()2,目的是直观的解答抛出的问题
  2. 实际项目中getList()方法内部有缓存数据处理,有考虑数据实时性的问题


进阶问题


  1. 比如需求变更为list2中的数据有一个状态,如果状态改变需要从list2列表中移动到list1列表中怎么处理?


思考


  1. 进阶问题考察的关键是状态改变,这个状态改变是实时变化的吗?实时变化的话,只有主动推送状态变化给客户端通知更新。
  2. 我们便引入了消息推送机制,保证数据结构体的一致性,当list2中的数据状态改变,就推送这条数据到客户端,又客户端添加到list1中


进阶思考


  1. 这样又引出了一个问题,list2中的数据如何移除,移除之后怎么保证再次翻页查找不会重复取数据,不会丢数据?
相关文章
|
4天前
|
存储 安全 算法
Java一分钟之-Java集合框架入门:List接口与ArrayList
【5月更文挑战第10天】本文介绍了Java集合框架中的`List`接口和`ArrayList`实现类。`List`是有序集合,支持元素重复并能按索引访问。核心方法包括添加、删除、获取和设置元素。`ArrayList`基于动态数组,提供高效随机访问和自动扩容,但非线程安全。文章讨论了三个常见问题:索引越界、遍历时修改集合和并发修改,并给出避免策略。通过示例代码展示了基本操作和安全遍历删除。理解并正确使用`List`和`ArrayList`能提升程序效率和稳定性。
11 0
|
4天前
|
存储 编译器 C++
【C++/STL】list(常见接口、模拟实现、反向迭代器、)
【C++/STL】list(常见接口、模拟实现、反向迭代器、)
5 0
|
4天前
List()接口
List()接口
|
4天前
使用Vant框架的组件van-pull-refresh搭配van-list和van-card完成上滑加载更多列表数据,下拉刷新当前列表数据(等同于翻页功能)
使用Vant框架的组件van-pull-refresh搭配van-list和van-card完成上滑加载更多列表数据,下拉刷新当前列表数据(等同于翻页功能)
|
7月前
|
存储 算法 Java
java集合框架------Collection接口,List接口与实现类,Set接口与实现类
java集合框架------Collection接口,List接口与实现类,Set接口与实现类
|
4天前
|
存储 安全 Java
深入解析Java List接口及其实现类
深入解析Java List接口及其实现类
|
4天前
|
索引
看一下List接口的常用方法
看一下List接口的常用方法
37 1
|
4天前
|
编译器 C++
|
7月前
|
XML 存储 JSON
java框架集合List子接口之ArrayList源码剖析
ArrayList使用尾删法时 , 时间复杂度为O(1) , 并且会把最后一个元素置位null , 其它删除时间复杂度为O(N) , 因为会涉及到元素的移动以及元素的遍历 ArrsyList是线程不安全的
26 0
|
7月前
|
存储 Java 索引
java集合框架List子接口之LinkedList源码剖析
LinkendList从物理结构来说是一种线性结构 , 而从逻辑结构来说是一种链式存储结构 , 虽然是线性结构 , 但是并不会按照线性的顺序存储 , 而是分散存储在内存中 , 通过指针来建立节点与节点之间的联系, 同时实现了Deque这也说明它是一个双向链表 , 在源码中 , 没有看到它对线程安全问题的处理 , 所以它同时还是一个线程不安全的链表 , 也没有看到不允许插入null元素 , 重复元素的处理 , 所以它又是一个允许重复元素以及null元素的链表
36 0