2017-11-28 18 views
0

私はカテゴリ別にアイテムをグループ化するxslテンプレートを持っています。今私はこれらのカテゴリの中で一緒にグループ化したいと思う。Xsl 1.0、二重グループ化

私のXSLスクリプト

<xsl:output method="xml" indent="yes" omit-xml-declaration="yes" /> 

    <xsl:variable name="prefix_param">udt_<xsl:value-of select="//udt:Context/udt:ModuleId" />_param</xsl:variable> 
    <xsl:key name="data-by-Category" match="udt:Data" use="udt:Category" /> 

    <xsl:template match="udt:Data" mode="list"> 
    <li> 
     <xsl:value-of select="udt:Subcategory" disable-output-escaping="yes" /> 
     <xsl:value-of select="udt:Information" disable-output-escaping="yes" /> 
    </li> 
    </xsl:template> 

    <xsl:template match="/udt:UserDefinedTable"> 
    <xsl:for-each select="udt:Data[count(. | key('data-by-Category', udt:Category)[1]) = 1]"> 
     <xsl:sort select="udt:Zap" /> 
     <span> 
     <h1> 
      <xsl:value-of select="udt:Category" disable-output-escaping="yes" />&#160;</h1> 
     </span> 
     <xsl:variable name="currentData" select="key('data-by-Category', udt:Category)" /> 
     <xsl:if test="$currentData"> 
     <ul> 
      <xsl:apply-templates select="$currentData" mode="list"> 
      <xsl:sort select="udt:PodCategory" order="ascending" /> 
      </xsl:apply-templates> 
     </ul> 
     </xsl:if> 
    </xsl:for-each> 
    </xsl:template> 

    <xsl:template name="EditLink"> 
    <xsl:if test="udt:EditLink"> 
     <a href="{udt:EditLink}"> 
     <img border="0" alt="edit" src="{//udt:Context/udt:ApplicationPath}/images/edit.gif" /> 
     </a> 
    </xsl:if> 
    </xsl:template> 

サンプル出力は、私が今得る:

<h1>Category 1</h1> 
<ul> 
<li>Subcategory 1 info 1</li> 
<li>Subcategory 2 info 1</li> 
<li>Subcategory 2 info 2</li> 
<li>Subcategory 2 info 3</li> 
</ul> 

<h1>Category 2</h1> 
<ul> 
<li>Subcategory 1 info 1</li> 
<li>Subcategory 1 info 2</li> 
<li>Subcategory 2 info 1</li> 
</ul> 

そして、これは私が達成したいサンプル出力です:

<h1>Category 1</h1> 
<h2>Subcategory 1</h2> 
<ul> 
<li>info 1</li> 
</ul> 
<h2>Subcategory 2</h2> 
<ul> 
<li>info 1</li> 
<li>info 2</li> 
<li>info 3</li> 
</ul> 

<h1>Category 2</h1> 
<h2>Subcategory 1</h2> 
<ul> 
<li>info 1</li> 
<li>info 2</li> 
</ul> 
<h2>Subcategory 1</h2> 
<ul> 
<li>info 1</li> 
</ul> 

私がしたいですセカンダリグループ内の各グループ内のアイテムを参照し、そのタイトルも表示します。

+0

問題をよりよく理解するために入力XMLを共有してください。 –

答えて

0

は、第2のキー

<xsl:key name="data-by-Category-and-Subcategory" match="udt:Data" use="concat(udt:Category, '|', udt:Subcategory)" /> 

を定義し、例えば、使用しますサブグループを特定すること

<xsl:template match="/udt:UserDefinedTable"> 
    <xsl:for-each select="udt:Data[count(. | key('data-by-Category', udt:Category)[1]) = 1]"> 
     <xsl:sort select="udt:Zap" /> 
     <span> 
     <h1> 
      <xsl:value-of select="udt:Category" disable-output-escaping="yes" />&#160;</h1> 
     </span> 
     <xsl:variable name="currentData" select="key('data-by-Category', udt:Category)" /> 
     <xsl:for-each select="$currentData[generate-id() = generate-id(key('data-by-Category-and-Subcategory', concat(udt:Category, '|', udt:Subcategory))[1])]"> 
     <h2><xsl:value-of select="udt:Subcategory"/></h2> 
     <xsl::variable name="$sub-group" select="key('data-by-Category-and-Subcategory', concat(udt:Category, '|', udt:Subcategory)"/> 

     <ul> 
      <xsl:apply-templates select="$sub-group" mode="list"> 
      <xsl:sort select="udt:PodCategory" order="ascending" /> 
      </xsl:apply-templates> 
     </ul> 
     </xsl:if> 
    </xsl:for-each> 
    </xsl:template> 
関連する問題