2

JSONata 提供了几个函数来操作数组内容。但是,我不知道如何返回找到的元素的索引(类似于 JavaScript 中的 Array.indexOf 函数)。我正在寻找类似的东西:

$indexOf(Account.Order[OrderID="order103"])
or
Account.Order.indexOf(OrderID="order103")
or
Account.Order[OrderID="order103"].index
4

3 回答 3

2

您可以合并地图的索引:

Account.Order ~> $map(function($v, $i) {
  $merge([{'Index': $i}, $v])
})~>function($x){$x[OrderID="order103"].Index}
于 2018-06-11T16:30:30.157 回答
2

试试这个:

Account.Order ~> $map(function($v, $i) { $v.OrderID = 'order103' ? $i })
于 2018-10-31T11:24:44.100 回答
0

如果找不到,两种提议的解决方案都不能确保有效响应,但添加额外的测试似乎符合我的预期:

($x:=Account.Order ~> $map(function($v, $i) { $v.OrderID = 'order101' ? $i });
$exists($x)?$x:-1)

将返回 -1

($x:=Account.Order ~> $map(function($v, $i) { $v.OrderID = 'order103' ? $i });
$exists($x)?$x:-1)

将返回 0

($x:=Account.Order ~> $map(function($v, $i) { $v.OrderID = 'order104' ? $i });
$exists($x)?$x:-1)

将返回 1

于 2019-01-08T22:33:21.967 回答