Как добавить второй элемент в массив JSON, только если он есть? - PullRequest
0 голосов
/ 20 февраля 2019

У меня есть несколько JSON связанных данных, и мне интересно, как добавить второй элемент в массив, если и только если есть второй элемент.

В моем случае добавление соавтора или двух соавторов к статье.

  script(type="application/ld+json").
    {
      "@context": "http://schema.org",
      "@type": "Article",
      "headline": "#{article.title}",
      "description": "#{article.description}",
      "author": [{
        "@type": "Person",
        "name": "#{article.author && article.author.name}",
        "givenName": "#{article.author && article.author.givenName}",
        "additionalName": "#{article.author && article.author.additionalName}",
        "familyName": "#{article.author && article.author.familyName}",
        "email": "#{article.author && article.author.email}",
        "jobTitle": "#{article.author && article.author.jobTitle}",
        "workLocation": "#{article.author && article.author.workLocation}",
        "worksFor": "Company",
        "image": "#{article.author && article.author.image}",
        "url": "#{article.author && article.author.url}",
        "sameAs": !{JSON.stringify(article.author && article.author.sameAs)}
      }],
      "datePublished": "#{article.date}",
      "dateModified": "#{article.updated || article.date}",
      "publisher": {
        "@type": "Organization",
        "name": "Company",
        "logo": {
          "@type": "ImageObject",
          "url": "...logo-url.jpg"
        }
      },
      "image": "#{article.image}",
      "url": "#{article.url}"
    }

В качестве шаблонного языка здесь используется pug.

Так как мне добавить второго человека?

     "sameAs": !{JSON.stringify(article.author && article.author.sameAs)}
  }
  if (coauthor) return ,{author-2}
  ],
     "datePublished": "#{article.date}",

1 Ответ

0 голосов
/ 21 февраля 2019

Один (немного обходной) способ сделать это состоит в том, чтобы заранее построить объект схемы в javascript с использованием небуферизованного блока кода, а затем вывести его в тег сценария, используя JSON.stringify().

Предполагая, что ваши данныеструктурирован так, что article.authors является массивом авторов:

-
  let jsonld = {
    '@context': 'http://schema.org',
    '@type': 'Article',
    'headline': article.title,
    'description': article.description,
    'datePublished': article.date,
    'dateModified': article.updated || article.date,
    'publisher': {
      '@type': 'Organization',
      'name': 'Company',
      'logo': {
        '@type': 'ImageObject',
        'url': '...logo-url.jpg'
      }
    },
    'image': article.image,
    'url': article.url
  }
  for (let i = 0; i < article.authors.length; i++) {
    jsonld.authors = jsonld.authors || []
    let author = {
      '@type': 'Person',
      'name': article.authors[i].name,
      'givenName': article.authors[i].givenName,
      'additionalName': article.authors[i].additionalName,
      'familyName': article.authors[i].familyName,
      'email': article.authors[i].email,
      'jobTitle': article.authors[i].jobTitle,
      'workLocation': article.authors[i].workLocation,
      'worksFor': 'Company',
      'image': article.authors[i].image,
      'url': article.authors[i].url,
      'sameAs': JSON.stringify(article.authors[i].sameAs
    }
    jsonld.authors.push(author)
  }

script(type="application/ld+json")= JSON.stringify(jsonld, null, 2)
...