我有一个像这样的嵌套对象
contract: {
packages: [
{
servicePoint: {
productType: {
name: 'Name1'
}
},
packages: [
{
servicePoint: {
productType: {
name: 'Name1'
}
}
},
{
servicePoint: {
productType: {
name: 'Name2'
}
}
}
]
}
]
}
我想遍历嵌套对象并查找所有 productType.name 值(如果存在)。并创建元素
<button type="button">{{ servicePoint.productType.name }}</button>
我可以做这样的事情
{% for servicePoint in contract.packages[0].packages[0].servicePoints %}
但它只会在第二级对象下找到属性。
我找到了一些解决方案
{% if contract.packages.length > 0 %}
{% for item in contract.packages %}
{% if item.servicePoints.length > 0 %}
{% set names = (names.push(item.servicePoints[0].productType.name), names) %}
{% endif %}
{% if item.packages.length > 0 %}
{% for value in item.packages %}
{% set names = (names.push(value.servicePoints[0].productType.name), names) %}
{% endfor %}
{% endif %}
{% endfor %}
{% endif %}
但是我遇到了新问题。如果它找到相同的 productType.name,它会创建两个具有相同值的按钮。
我怎么能 uniq productType.name ?