function Rss::render
Render the display in this style.
Overrides StylePluginBase::render
File
- 
              core/
modules/ views/ src/ Plugin/ views/ style/ Rss.php, line 111  
Class
- Rss
 - Default style plugin to render an RSS feed.
 
Namespace
Drupal\views\Plugin\views\styleCode
public function render() {
  $rows = [];
  // This will be filled in by the row plugin and is used later on in the
  // theming output.
  $this->namespaces = [
    'xmlns:dc' => 'http://purl.org/dc/elements/1.1/',
  ];
  // Fetch any additional elements for the channel and merge in their
  // namespaces.
  $this->channel_elements = $this->getChannelElements();
  foreach ($this->channel_elements as $element) {
    if (isset($element['namespace'])) {
      $this->namespaces = array_merge($this->namespaces, $element['namespace']);
    }
  }
  foreach ($this->view->result as $row_index => $row) {
    $this->view->row_index = $row_index;
    $rows[] = $this->view->rowPlugin
      ->render($row);
  }
  $build = [
    '#theme' => $this->themeFunctions(),
    '#view' => $this->view,
    '#options' => $this->options,
    '#rows' => $rows,
    '#attached' => [
      'http_header' => [
        [
          'Content-Type',
          'application/rss+xml; charset=utf-8',
        ],
      ],
    ],
  ];
  unset($this->view->row_index);
  return $build;
}
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.