Nunjucks 嵌套对象数组字段打印

Nunjucks nested object array field printing

我的数组数据:

data = [
  { field: { name:"name1", title:"title1" } },
  { field: { name:"name2", title:"title2" } },
  { field: { name:"name3", title:"title3" } }
];

我想这样写 name 字段:

预期输出

name1.name2.name3


我需要加入这些对象的指定字段值,但我不知道如何得到它们。

我尝试过但失败了 =>

data | selectattr("field") | selectattr("name") | join(".") }}

selectattr-仅过滤器 filter data elements。因此,当您应用 selectattr('name') 时,nunjucks 会尝试通过具有 name 字段(其中 none 个)和 returns 空结果的元素来过滤 data

实现 name1.name2.name3 的最简单方法是使用自定义过滤器

const nunjucks  = require('nunjucks');
const env = nunjucks.configure();

env.addFilter('map', function (arr, prop, ...etc) {
    const f = typeof prop == 'function' ? 
        prop : typeof env.filters[prop] == 'function' ? 
        env.filters[prop] : (e) => e[prop]; 

    return arr instanceof Array && arr.map(e => f(e, ...etc)) || arr;
});

const data = [
  {field: {name: "name1", title: "title1"}},
  {field: {name: "name2", title: "title2"}},
  {field: {name: "name3", title: "title3"}}
];

const html = env.renderString(`{{ data | map('field') | map('name') | join('.') }}`, {data});

console.log(html);