Я хочу, чтобы моя XSLT-проверка проверяла, пусты ли все <field>
в случайных вкладках панели. Если все они пусты, я хочу, чтобы он возвращал <p>All are empty</p>
, но если это не так, я хочу, чтобы содержимое panelTabs с полями находилось внутри <div id='tabItems'>
, с той же позицией, что и в XML. Пожалуйста, помогите мне.
XML:
<document>
<contentTabs>
<panelTabs text='a'>
<row type='header'>
<column>H1</column>
<column>H2</column>
</row>
<row type='data'>
<column>D1</column>
<column>D2</column>
</row>
</panelTabs>
<panelTabs text='b'>
<field> </field>
<field> </field>
</panelTabs>
<panelTabs text='c'>
<field>x1</field>
<field>x2</field>
</panelTabs>
<contentTabs>
</document>
Текущий XSLT:
<xsl:template match='contentTabs'>
<ul id='ulTabKopjes' class='tabKopjes'>
<li onclick='verschuifTabs(this)'><</li>
<xsl:call-template name='liHeaders' />
<li onclick='verschuifTabs(this)'>></li>
</ul>
<div class='tabContent'>
<xsl:apply-templates />
</div>
</xsl:template>
<xsl:template name='liHeaders'>
<xsl:for-each select='panelTabs'>
<li onclick='loadPanelTabContent(this)'>
<xsl:value-of select="@text" />
</li>
</xsl:for-each>
</xsl:template>
<xsl:template match="panelTabs">
<div class="tabItems">
<xsl:attribute name="id">
<xsl:text>tabnr</xsl:text><xsl:value-of select="position()" />
</xsl:attribute>
<xsl:apply-templates />
</div>
</xsl:template>
<xsl:template match="panelTabs[not(field[normalize-space()])]">
<p>All are empty</p>
</xsl:template>
<xsl:template match="panelTabs/field">
<p><xsl:value-of select="." /></p>
</xsl:template>
<xsl:template match="panelTabs/field[not(normalize-space())]" priority="2" />
Пробовал только XSLT без последнего <panelTabs>
Требуемый вывод, что-то вроде:
<ul id='ulTabKopjes' class='tabKopjes'>
<li onclick='verschuifTabs(this)'><</li>
<li onclick='loadPanelTabContent(this)'>a</li>
<li onclick='loadPanelTabContent(this)'>b</li>
<li onclick='loadPanelTabContent(this)'>c</li>
<li onclick='verschuifTabs(this)'>></li>
</ul>
<div id='tabContent'>
<div class='tabItems' id='tabnr1'>
<table>something</table>
</div>
<div class='tabItems' id='tabnr2'>
<p>All fields are empty</p>
</div>
<div class='tabItems' id='tabnr3'>
<p>x1</p>
<p>x2</p>
</div>
</div>
panelTab
с полями, имеющими некоторые значения, и показать ожидаемый результат для этого тоже.. - person Lingamurthy CS   schedule 11.12.2014