Как объявить и перебрать массив в XSLT?

Мое требование - использовать XSLT-, чтобы отобразить выпадающий список в штатах США и напечатать "выбранный" на одном конкретном, объявленном в XML, который будет использовать мою таблицу стилей.

Я думал о объявлении массива с состояниями и повторил его, но я не знаю, как это сделать.

ПРИМЕЧАНИЕ. Больше идей приветствуются;)

Ответ 1

Один из способов сделать это - вставить данные состояния в таблицу стилей и получить доступ к документу таблицы стилей с помощью document('') следующим образом:

<xsl:stylesheet version="1.0"
  xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
  xmlns:my="whatever"
  exclude-result-prefixes="my">

  <xsl:output indent="yes"/>

  <!-- The value of the state you want to select, supplied in the input XML -->
  <xsl:variable name="selected-state" select="/xpath/to/state/value"/>

  <!-- You have to use a namespace, or the XSLT processor will complain -->
  <my:states>
    <option>Alabama</option>
    <option>Alaska</option>
    <!-- ... -->
    <option>Wisconsin</option>
    <option>Wyoming</option>
  </my:states>

  <xsl:template match="/">
    <!-- rest of HTML -->
    <select name="state">
      <!-- Access the embedded document as an internal "config" file -->
      <xsl:apply-templates select="document('')/*/my:states/option"/>
    </select>
    <!-- rest of HTML -->
  </xsl:template>

          <!-- Copy each option -->
          <xsl:template match="option">
            <xsl:copy>
              <!-- Add selected="selected" if this is the one -->
              <xsl:if test=". = $selected-state">
                <xsl:attribute name="selected">selected</xsl:attribute>
              </xsl:if>
              <xsl:value-of select="."/>
            </xsl:copy>
          </xsl:template>

</xsl:stylesheet>

Сообщите мне, если у вас есть какие-либо вопросы.

Ответ 2

В идеале вы сохраните список состояний в вашем XML файле и просто используйте XSLT для их итерации.

Обновление: Если вы не можете редактировать XML, вы можете использовать функцию для работы с документами для загрузки данных из второго файла данных: