XSL-为节点内的每个生成一个



大约三周前,我发布了一个关于XSL1.0的问题,每个问题都得到了很好的答案。但现在我需要一些关于在节点内为每个节点创建一个的建议。我很确定这是个棘手的问题,但请帮帮我。

我的XML:

<?xml version="1.0" encoding="utf-8" ?> 
  <eOrden xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
    <EquipoServicio>
      <eElemento>
        <Clave>PAMO1</Clave> 
        <Descripcion>MODEM</Descripcion> 
      </eElemento>
      <eElemento>
        <Clave>ISP01</Clave> 
        <Descripcion>PRODIGY</Descripcion> 
      </eElemento>
      <eElemento>
        <Clave>IFR28</Clave> 
        <Descripcion>ACCESS</Descripcion> 
      </eElemento>
    </EquipoServicio>
  </eOrden>

我的XSL(到目前为止):

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:template match="/eOrden">
    <html>
        <head></head>
          <body>
            <div>
                <section class="sections">
                    <fieldset>
                        <legend class="lbold">EQUIPO O SERVICIO</legend>
                        <div class="primerdiv" style="width:99.5%; padding-top:5px; padding-bottom: 7px; ">
                            <xsl:for-each select="EquipoServicio/eElemento[position() mod 7 = 1]" >
                                <div class="primerdiv letra" style="width:12.3%;">
                                    <div class="primerdiv letra" style="padding-top:2px; padding-bottom: 2px; width:100%">
                                        <div class="primerdiv eqsertitulo lbold" style="text-align:right; width:100%">
                                            EQ. O SERV.:&#xA0;
                                         </div>
                                         <div class="primerdiv eqsertitulo lbold" style="text-align:right; width:100%">
                                            DESCR.:&#xA0;
                                         </div>
                                      </div>
                                   </div>
                                <xsl:apply-templates select=". | following-sibling::EquipoServicio/eElemento[position() &lt; 7]"/>
                            </xsl:for-each>
                        </div>
                    </fieldset>
                </section>
            </div>
          </body>
    </html>
</xsl:template>
<xsl:template match="eElemento">
    <div class="altbordeptes" style="float:left; width:12%;">
        <div class="primerdiv letra" style="width:98.5%;">
            <div class="eqser letra" style="border: 1px solid #D0D0D0; text-align:left; width:98.5%;">
                <xsl:value-of select="Clave"/>
            </div>
        </div>
        <div class="primerdiv letra" style="width:98.5%;">
            <div class="eqser letra" style="border: 1px solid #D0D0D0; text-align:left; width:99.5%;">
                <xsl:value-of select="Descripcion"/>
            </div>
        </div>
    </div>
</xsl:template>
</xsl:stylesheet>

为什么,如果我运行这个,迭代只得到第一个eElemento节点的信息,而不是整个三个节点的信息?如果我在EquipoServicio节点之外取eElemento节点,则输出是正确的!!

我期望的结果是这样的:

<section class="sections">
         <fieldset>
            <legend class="lbold">EQUIPO O SERVICIO</legend>
            <div class="primerdiv" style="width:99.5%; padding-top:5px; padding-bottom: 7px; ">
               <div class="primerdiv letra" style="width:12.3%;">
                  <div class="primerdiv letra" style="padding-top:2px; padding-bottom: 2px; width:100%">
                     <div class="primerdiv eqsertitulo lbold" style="text-align:right; width:100%">
                                                            EQ. O SERV.:&nbsp;
                     </div>
                     <div class="primerdiv eqsertitulo lbold" style="text-align:right; width:100%">
                                                               DESCR.:&nbsp;
                     </div>
                  </div>
               </div>
               <div class="altbordeptes" style="float:left; width:12%;">
                  <div class="primerdiv letra" style="width:98.5%;">
                     <div class="eqser letra" style="border: 1px solid #D0D0D0; text-align:left; width:100%;">PAMO1</div>
                  </div>
                  <div class="primerdiv letra" style="width:98.5%;">
                     <div class="eqser letra" style="border: 1px solid #D0D0D0; text-align:left; width:100%;">MODEM</div>
                  </div>
               </div>
               <div class="altbordeptes" style="float:left; width:12%;">
                  <div class="primerdiv letra" style="width:98.5%;">
                     <div class="eqser letra" style="border: 1px solid #D0D0D0; text-align:left; width:100%;">ISP01</div>
                  </div>
                  <div class="primerdiv letra" style="width:98.5%;">
                     <div class="eqser letra" style="border: 1px solid #D0D0D0; text-align:left; width:100%;">PRODIGY</div>
                  </div>
               </div>
               <div class="altbordeptes" style="float:left; width:12%;">
                  <div class="primerdiv letra" style="width:98.5%;">
                     <div class="eqser letra" style="border: 1px solid #D0D0D0; text-align:left; width:100%;">IFR28</div>
                  </div>
                  <div class="primerdiv letra" style="width:98.5%;">
                     <div class="eqser letra" style="border: 1px solid #D0D0D0; text-align:left; width:100%;">ACCESS</div>
                  </div>
               </div>
            </div>
         </fieldset>
      </section>

提前谢谢。托尼奥。

尝试更改:

<xsl:apply-templates select=". | following-sibling::EquipoServicio/eElemento[position() &lt; 7]"/>

至:

<xsl:apply-templates select=". | following-sibling::eElemento[position() &lt; 7]"/>

这两者并不完全相同。


注意

您的输入无效:EquipoServicio元素没有结束标记。最好去掉所有与问题无关的"噪音"(例如CSS)。

相关内容

  • 没有找到相关文章

最新更新