Kotlin 反应器-加载分页API的所有页面
我想知道Reactor和分页HTTP API。我有一个Kotlin 反应器-加载分页API的所有页面,kotlin,project-reactor,reactor,Kotlin,Project Reactor,Reactor,我想知道Reactor和分页HTTP API。我有一个私人娱乐页面(页码:Int):Mono。资源有一个“numberOfPages”字段,我想获取所有页面 第一次尝试如下: getPage(1) .map { it.numberOfPages } .flatMapMany { Flux.range(1, it) } .flatMap { getPage(it) } 它工作并获取我的数据。但是,我希望避免两次请求第一页。所以我想: getPage(1) .exp
私人娱乐页面(页码:Int):Mono
。资源有一个“numberOfPages”字段,我想获取所有页面
第一次尝试如下:
getPage(1)
.map { it.numberOfPages }
.flatMapMany { Flux.range(1, it) }
.flatMap { getPage(it) }
它工作并获取我的数据。但是,我希望避免两次请求第一页。所以我想:
getPage(1)
.expand { it ->
if (it.isFirst) {
// If it is the first page, load the rest of the pages
Flux.range(2, it.numberOfPages)
.flatMap { getPage(it) }
} else {
// If it is a subsequent page, don't load anything
Flux.empty()
}
}
有没有更好的方法来实现这一点,而不是使用
expand
并在我的参考资料中引入一个特殊标志?您可以执行以下操作:
getPage(1).flatMapMany(
it -> Flux.concat(Mono.just(it), Flux.range(2, it.numberOfPages - 1).flatMap(this::getPage))
);
恐怕这是Java而不是Kotlin,但这应该是很容易翻译的
(请记住
Flux.range()
适用于“开始”和“计数”参数,而不是“第一个索引”和“最后一个索引”。啊,是的,看起来不错,谢谢。感谢Flux.range的提醒,完全错过了。然后你就可以取消“如果”条件了,对吧?因为如果numberOfPages==1
,那么通量范围(2,0)
将是一个空通量。我喜欢你的解决方案,因为我不需要为“isFirst”费心。这比使用expand更“反应器惯用”吗?@Kehrlann-Doh,当然-我正确地解释了Flux.range()
,然后忘记了在答案中暗示这个想法!现在更新了。@Kehrlann抱歉,错过了第二点。是的,根据我的经验,expand()
是一个相对少见的操作符,在Flux.range()
上的映射更为正常。这并不是说前者是错误的,甚至不是说游戏状态将保持这种状态(反应堆仍然是一个相当利基的领域)——这只是我目前的经验。