JSONata 提供了几个函数来操作数组内容。但是,我不知道如何返回找到的元素的索引(类似于 JavaScript 中的 Array.indexOf 函数)。我正在寻找类似的东西:
$indexOf(Account.Order[OrderID="order103"])
or
Account.Order.indexOf(OrderID="order103")
or
Account.Order[OrderID="order103"].index
JSONata 提供了几个函数来操作数组内容。但是,我不知道如何返回找到的元素的索引(类似于 JavaScript 中的 Array.indexOf 函数)。我正在寻找类似的东西:
$indexOf(Account.Order[OrderID="order103"])
or
Account.Order.indexOf(OrderID="order103")
or
Account.Order[OrderID="order103"].index
您可以合并地图的索引:
Account.Order ~> $map(function($v, $i) {
$merge([{'Index': $i}, $v])
})~>function($x){$x[OrderID="order103"].Index}
试试这个:
Account.Order ~> $map(function($v, $i) { $v.OrderID = 'order103' ? $i })
如果找不到,两种提议的解决方案都不能确保有效响应,但添加额外的测试似乎符合我的预期:
($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