我可以使用"startAfter“和"limit”来进行分页,但它有错误。
例如,在Firestore DB中,我有7条记录:
{"title": "item1", "create_datetime": "2018-11-11 11:11:11"}
{"title": "item2", "create_datetime": "2018-11-11 11:11:11"}
{"title": "item3", "create_datetime": "2018-11-11 11:11:11"}
{"title": "item4", "create_datetime": "2018-11-11 11:11:11"}
{"title": "item5", "create_datetime": "2018-11-11 11:11:11"}
{"title": "item6", "create_datetime": "2018-11-11 11:11:11"}
{"title": "item7", "create_datetime": "2018-12-22 22:22:22"}当页面大小为5时,第一页就可以了,因为我使用了:
.orderBy('create_datetime').limit(5)它给我提供了1-5项。
当它加载第二个页面时,我使用:
.orderBy('create_datetime').startAfter(['2018-11-11 11:11:11']).limit(5)问题是第二个页面结果只有item7,item6消失了。"startAt“也有同样的问题。
我真的希望它有“偏移”功能。有谁有解决方案吗?
发布于 2018-12-03 15:45:04
您的查询将始终返回'item7‘,因为您总是在2018-11-11 11:11:11之后开始,所以它将忽略所有其他项,并转到最后一个2018-11-11 11:11:11并从那里跳过。您需要获取返回的最后一项并保留对它的引用,然后在startAfter上使用文档引用开始。通常,flutter的startAfter需要一个列表来保存对它的引用。
发布于 2019-02-22 16:31:57
目前flutter不支持startAfter(lastDocFetched)或startAt(anyDoc)。正如您所说的,这是必需的,因为它从字符串匹配值开始,而不是从特定的文档开始。
https://stackoverflow.com/questions/53491952
复制相似问题