Oprettet tor. d. 05. november 2009 kl. 09:53:50

stig69
stig69 (17.344 point. Point ude: 1.040)

Liste menu

Jeg har en udfordring med min liste menu i XSLT, hvor jeg har behov for at tilføje forskellige klasser til det aktive <li> tags. Der skal være en differentiering, når menupunktet er aktivt og indeholder underpunkter, og når menupunktet er aktivt men ikke indeholder underpunkter. Illustreret således:

Eksempel 1 (page 2 er valgt og har underpunkter):
<ul class="Level-1">
  <li class="Level-1"><a href="#">page 1</a></li>
  <li class="Level-1-actSub"><a href="#">page 2</a></li>
  <li class="nextLevel">
    <ul class="Level-2">
      <li class="Level-2"><a href="#">page 2-1</a></li>
      <li class="Level-2"><a href="#">page 2-2</a></li>
    </ul>
  </li>
  <li class="Level-1"><a href="#">page 5</a></li>
</ul>


Eksempel 2 (page 5 er valgt og har ingen underpunkter):
<ul class="Level-2">
  <li class="Level-1"><a href="#">page 1</a></li>
  <li class="Level-1"><a href="#">page 2</a></li>
  <li class="Level-1-act"><a href="#">page 5</a></li>
</ul>

Spørgsmålet er hvorledes jeg får lavet denne differentiering med XSLT???


Min XSLT indtil videre, som fungerer:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE xsl:Stylesheet [
  <!ENTITY nbsp " ">
]>
<xsl:stylesheet
version="1.0"
xmlns:xsl="http://www.w3.org/ (...)
xmlns:msxml="urn:schemas-microsoft-com:xslt"
xmlns:umbraco.library="urn:umbraco.library"
exclude-result-prefixes="msxml umbraco.library">

  <xsl:output method="xml" omit-xml-declaration="yes" />
  <xsl:param name="currentPage"/>
  <xsl:variable name="level" select="2"/>
  <xsl:variable name="documents" select="$currentPage/ancestor-or-self::node [@level=$level]/node [string(data [@alias='NavigationHide']) != '1']" />
  <xsl:template match="/">
    <xsl:if test="count($documents) > 0">
      <ul class="Level-1">
        <!-- Change li class for selected level 2 node -->
        <xsl:for-each select="$documents">
          <li class="Level-2">
            <xsl:if test="$currentPage/ancestor-or-self::node/@id = ./@id">
              <xsl:attribute name="class">Level-2-act</xsl:attribute>
            </xsl:if>
              <a href="{umbraco.library:NiceUrl(./@id)}"><xsl:value-of select="./@nodeName"/></a>
          </li>

          <!-- Select level 2 nodes and create a list -->
          <xsl:if test="$currentPage/ancestor-or-self::node/@id = ./@id">
            <xsl:if test="count(./child::node [string(data [@alias='umbracoNaviHide']) != '1']) > 0">
              <li class="nextLevel">
                <ul class="Level-2">
                  <xsl:for-each select="./child::node [string(data [@alias='NavigationHide']) != '1']">
                    <li class="Level-2">
                      <!-- change class if selected -->
                      <xsl:if test="$currentPage/ancestor-or-self::node/@id = ./@id">
                        <xsl:attribute name="class">Level-3-act</xsl:attribute>
                      </xsl:if>
                      <a href="{umbraco.library:NiceUrl(./@id)}"><xsl:value-of select="./@nodeName"/></a>
                    </li>
                  </xsl:for-each>
                </ul>
              </li>
            </xsl:if>
          </xsl:if>
        </xsl:for-each>

      </ul>
    </xsl:if>
  </xsl:template>

</xsl:stylesheet>

Mvh

Stig

Skriv et indlæg




Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] [img]link til billede[/img]
Web- og emailadresser omdannes automatisk til links

Log ind

   

   

Seneste spørgsmål

Benytte XSLT til tranformering af data imellem 2 systemer

Oprettet den 8. december 2011 kl. 11.52
bongo13 giver 60 point for svar | Giv et svar »

fo:block kollapser

Oprettet den 14. november 2011 kl. 11.16
schristensen giver 200 point for svar | Giv et svar »

Select i Xpath, ignorere case

Oprettet den 20. oktober 2011 kl. 00.01
wise giver 30 point for svar | Giv et svar »

Seneste guides

Installer win 7
Den gode bruger


   




Tips & Tricks fra PC World

Teaser billede

Her er fem sjove danske websider du skal kende

Trænger dine lattermuskler til en omgang fitness på dansk? Vi viser vej til fem websider fyldt med humor og vanvittig satire.


Anmeldelser fra PC World

Teaser billede

Test: Denne super-tablet er iPads hårdeste konkurrent

Eee Pad Transformer Prime er frygtindgydende med sin quadcore processor og evne til at trylle sig om til bærbar. Apple bør kigge i bagspejlet, for Asus' tablet-pc kommer buldrende - og gør det...


Seneste blogindlæg

Teaser billede

Tvangslukke spørgsmål: Hvad er den bedste løsning?

Hej Vi har mange åbne spørgsmål på Eksperten. Vi ville gerne tvangslukke dem - så et spørgsmål efter f.eks. 6 måneder lukkes. Men der er et par uklarheder som ville være gode at få lidt input til:...


Nyheder fra PC World

Teaser billede

Nu kan du snart hente Windows 8

Den nye offentlige betaversion af Windows 8 er klar i denne måned.


Nyheder fra Computerworld

Teaser billede

Måske snart slut med Androids helt store problem

Android-platformen har længe været plaget af et særligt problem. Men måske er problemet nu ved at være elimineret.


Kurser
Samarbejdspartnere

Udgiver · © 2012 IDG Danmark A/S · Hørkær 18 · 2730 Herlev · Tlf.: 77 300 300 · Fax: 77 300 301 · Brug af personoplysninger