我认为这个问题非常自我解释。如何在map,filter和其他循环的运算符中打破循环? (或者至少是解决方法)
谢谢
您无法使用任何内置函数(如map
,filter
和reduce
)来执行此操作,因此这会让您进行递归。要模拟中断,您的基本案例将需要检查数组的长度以及中断条件。这是一个接受数组并返回包含每个值的数组的示例,直到达到偶数:
%dw 1.0
output application/json
%function breakCondition(n)
mod(n, 2) == 0
%function untilEven(arr, out=[])
out when (isEmpty(arr) or breakCondition(arr[0]))
otherwise untilEven(arr[1 to -1], arr[0])
---
untilEven([3, 5, 1, 6, 7, 9])
返回:
[3, 5, 1]
供将来参考,以下是2.0中的相同示例:
%dw 2.0
output application/json
fun breakCondition(n) =
mod(n, 2) == 0
fun untilEven(arr, out=[]) =
if (isEmpty(arr) or breakCondition(arr[0]))
out
else
untilEven(arr[1 to -1], arr[0])
---
untilEven([3, 5, 1, 6, 7, 9])