1

これはとてもシンプルなはずです!メニュー階層を含む XML ドキュメントがあります。

<?xml version="1.0" encoding="utf-8"?>
<menu page_id="18" language="en-GB">
    <item id="1" child_of="0">
        <menu_order>1</menu_order>
        <title><![CDATA[Home]]></title>
    </item>
    <item id="18" child_of="0">
        <title><![CDATA[Page One]]></title>
        <submenu child_of="18">
            <item id="20" child_of="18">
                <title><![CDATA[Sub Menu One]]></title>
                <submenu child_of="20">
                    <item id="26" child_of="20">
                        <title><![CDATA[SubMenu 1-1]]></title>
                    </item>
                    <item id="27" child_of="20">
                        <title><![CDATA[SubMenu 1-2]]></title>
                    </item>
                </submenu>
            </item>
            <item id="21" child_of="18">
                <title><![CDATA[Sub Menu Two]]></title>
                <submenu child_of="21">
                    <item id="28" child_of="21">
                        <title><![CDATA[SubMenu 2-1]]></title>
                    </item>
                    <item id="29" child_of="21">
                        <title><![CDATA[SubMenu 2-2]]></title>
                        <submenu child_of="29">
                            <item id="32" child_of="29">
                                <title><![CDATA[SubMenu 2-2-1]]></title>
                            </item>
                            <item id="33" child_of="29">
                                <title><![CDATA[SubMenu 2-2-2]]></title>
                            </item>
                        </submenu>
                    </item>
                    <item id="30" child_of="21">
                        <title><![CDATA[SubMenu 2-3]]></title>
                    </item>
                    <item id="31" child_of="21">
                        <title><![CDATA[SubMenu 2-4]]></title>
                    </item>
                </submenu>
            </item>
            <item id="22" child_of="18">
                <title><![CDATA[Sub Menu Three]]></title>
            </item>
        </submenu>
    </item>
    <item id="19" child_of="0">
        <title><![CDATA[Page Two]]></title>
    </item>
</menu>

(1) アクティブ/クリックされたメニュー項目にサブメニューがある場合、その下にサブメニュー (メニューの子項目のみ) が表示される HTML リストに変換する必要があります。たとえば、item id = "18" をクリックすると、次のようになります。

<ul>
    <li id="1">Home</li>
    <li id="18">Page One
        <ul>
            <li id="20">Sub Menu One</li>
            <li id="21">Sub Menu Two</li>
            <li id="22">Sub Menu Three</li>
        </ul>
    </li>
    <li id="19">Page Two</li>
</ul>

または (2) アクティブなメニュー項目に祖先がある場合、構造内の直接の兄弟と祖先のすべてをレンダリングします。たとえば、item id="33" をクリックすると、次のようになります。

<ul>
    <li id="1">Home</li>
    <li id="18">Page One<ul>
            <li id="20">Sub Menu One</li>
            <li id="21">Sub Menu Two<ul>
                    <li id="28">SubMenu 2-1</li>
                    <li id="29">SubMenu 2-2
                        <ul>
                            <li id="32">SubMenu 2-2-1</li>
                            <li id="33">SubMenu 2-2-2</li>
                        </ul>
                    </li>
                    <li id="30">SubMenu 2-3</li>
                    <li id="31">SubMenu 2-4</li>
                </ul>
            </li>
            <li id="22">Sub Menu Three</li>
        </ul>
    </li>
    <li id="19">Page Two</li>
</ul>

問題は、私の XSL スタイル シートが 2 つの祖先サブメニューを含むリストを生成することです! 助けてください...私はこれに何時間も費やしました!ここに私のXSLTがあります:

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
    <xsl:output indent="yes"/>
    <!-- The DOM ID of the active menu item -->
    <xsl:param name="activeItemID"/>

    <xsl:template match="text()">
        <xsl:apply-templates/>
    </xsl:template>

    <xsl:template match="menu">
        <ul>
            <xsl:choose>
                <xsl:when test="//item[@id = $activeItemID]/@child_of = '0'">
                    <xsl:choose>
                        <xsl:when test="//submenu[@child_of = $activeItemID]/node()">
                            <xsl:apply-templates
                                select="//item[@child_of = '0'] | //submenu[@child_of = $activeItemID]"/>
                        </xsl:when>
                        <xsl:otherwise>
                            <xsl:apply-templates select="//item[@child_of = '0']"/>
                        </xsl:otherwise>
                    </xsl:choose>
                </xsl:when>
                <xsl:otherwise>
                    <xsl:choose>
                        <xsl:when test="//submenu[@child_of = $activeItemID]/node()">
                            <xsl:apply-templates
                                select="//item[@child_of = '0'] | //submenu[@child_of = $activeItemID]/ancestor-or-self::submenu/item"
                            />
                        </xsl:when>
                        <xsl:otherwise>
                            <xsl:apply-templates
                                select="//item[@child_of = '0'] | //item[@id = $activeItemID]/ancestor-or-self::submenu"
                            />
                        </xsl:otherwise>
                    </xsl:choose>
                </xsl:otherwise>
            </xsl:choose>
        </ul>
    </xsl:template>

    <xsl:template match="item">
        <li>
            <xsl:value-of select="title" disable-output-escaping="no"/>
            <xsl:apply-templates select="submenu[@child_of = $activeItemID]"/>
        </li>
    </xsl:template>

    <xsl:template match="submenu">
        <ul>
            <xsl:apply-templates select="item[@child_of = $activeItemID]">
                <xsl:sort select="menu_order" data-type="number"/>
            </xsl:apply-templates>
        </ul>
    </xsl:template>

</xsl:stylesheet>
4

1 に答える 1

2

このXSLTは、あなたが探していることを実行する必要があります。

<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
  <xsl:output indent="yes"/>
  <!-- The DOM ID of the active menu item -->
  <xsl:param name="activeItemID" />

  <xsl:template match="menu | submenu">
    <ul>
      <xsl:apply-templates select="item" />
    </ul>
  </xsl:template>

  <xsl:template match="item">
    <li id="{@id}">
      <xsl:value-of select="title" />
      <xsl:apply-templates select="submenu[..//@id = $activeItemID]"/>
    </li>
  </xsl:template>
</xsl:stylesheet>

パラメータ値を18としてサンプル入力で実行すると、次のようになります。

<ul>
  <li id="1">Home</li>
  <li id="18">
    Page One<ul>
      <li id="20">Sub Menu One</li>
      <li id="21">Sub Menu Two</li>
      <li id="22">Sub Menu Three</li>
    </ul>
  </li>
  <li id="19">Page Two</li>
</ul>

パラメータ値を33として実行すると、次のようになります。

<ul>
  <li id="1">Home</li>
  <li id="18">
    Page One<ul>
      <li id="20">Sub Menu One</li>
      <li id="21">
        Sub Menu Two<ul>
          <li id="28">SubMenu 2-1</li>
          <li id="29">
            SubMenu 2-2<ul>
              <li id="32">SubMenu 2-2-1</li>
              <li id="33">SubMenu 2-2-2</li>
            </ul>
          </li>
          <li id="30">SubMenu 2-3</li>
          <li id="31">SubMenu 2-4</li>
        </ul>
      </li>
      <li id="22">Sub Menu Three</li>
    </ul>
  </li>
  <li id="19">Page Two</li>
</ul>

XSLTにはいくつかの並べ替えロジックがありましたが、並べ替えに使用されていた要素は、ソースXMLの1か所にしか存在していないようでした。それはあなたが使いたかったものでしたか?menu_order簡単にするために、ソースXMLからほとんどの要素を省略しましたか?

于 2013-03-01T13:33:01.510 に答える