如何在xsl中添加jquery函数(Date)

时间:2017-12-14 14:41:48

标签: javascript jquery xml date xslt

我将日期作为字符串获取,需要以如下格式显示日期:MM / DD / YYYY 如果只有一年我应该添加01/01。 我还需要用大胆的方式显示今天2年以上的专辑。 我该怎么做呢?如何添加功能? 我只能使用JQUERY而不能使用JS。 感谢。

这是我的xsl:

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0"
      xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
      xmlns:ms="urn:schemas-microsoft-com:xslt"
      xmlns:dt="urn:schemas-microsoft-com:datatypes">
  <xsl:template match="/">
<html> 
<body>
<style>
u { 
    text-decoration: underline;
    font-weight: bold;
}
</style>
  <table border="1">
    <tr bgcolor="#979994">
      <th style="text-align:left">Price</th>
      <th style="text-align:left">Link</th>
      <th style="text-align:left">Company</th>
      <th style="text-align:left">Name</th>
      <th style="text-align:left">Date</th>
      <th style="text-align:left">Artist</th>
    </tr>
    <xsl:for-each select="Albums/Album">
    <tr>
      <td><xsl:value-of select="Price"/></td>
      <td><xsl:value-of select="Link"/></td>
      <td><xsl:value-of select="Company"/></td>
      <td><xsl:value-of select="Name"/></td>
      <td><xsl:value-of select="Date" /></td>
      <td style="color:red;"><xsl:value-of select="Artist"/></td>
    </tr>
    </xsl:for-each>
  </table>
</body>
</html>
</xsl:template>
</xsl:stylesheet>

和xml:

<?xml version="1.0" encoding="ISO8859-1"?>
<?xml-stylesheet type="text/xsl" href="Albums1.xs"?>
<Albums>
    <Album>
        <Name>Empire Burlesque</Name>
        <Artist>Bob Dylan</Artist>
        <Country>USA</Country>
        <Company>Columbia</Company>
        <Date>19880610</Date>
    </Album>
    <Album>
        <Name>Hide your heart</Name>
        <Artist>Bonnie Tylor</Artist>
        <Country>UK</Country>
        <Company>CBS Records</Company>
        <Price>9.90</Price>
        <Date>19880509</Date>
    </Album>
    <Album>
        <Name>Greatest Hits</Name>
        <Artist>Dolly Parton</Artist>
        <Country>USA</Country>
        <Company>RCA</Company>
        <Price>9.90</Price>
        <Date>1982</Date>
    </Album>
    <Album>
        <Name>Still got the blues</Name>
        <Artist>Gary More</Artist>
        <Country>UK</Country>
        <Company>Virgin redords</Company>
        <Price>10.20</Price>
        <Date>1990</Date>
    </Album>
    <Album>
        <Name>Eros</Name>
        <Artist>Eros Ramazzotti</Artist>
        <Country>EU</Country>
        <Company>BMG</Company>
        <Price>9.90</Price>
        <Date>1997</Date>
    </Album>
    <Album>
        <Name>25</Name>
        <Artist>Adele</Artist>
        <Country>UK</Country>
        <Company>XL Recordings</Company>
        <Price>9.90</Price>
        <Date>20151120</Date>
    </Album>
    <Album>
        <Name>1000 Forms of Fear</Name>
        <Artist>Sia</Artist>
        <Country>USA</Country>
        <Company>RCA Records</Company>
        <Price>9.90</Price>
        <Date>20140704</Date>
    </Album>
    <Album>
        <Name>Rattle and Hum</Name>
        <Artist>U2</Artist>
        <Country>EU</Country>
        <Company>Island</Company>
        <Price>9.90</Price>
        <Date>19881010</Date>
    </Album>
</Albums>

1 个答案:

答案 0 :(得分:0)

虽然可以在XSLT中调用javascript函数,但它非常依赖于处理器。但是,你根本不需要javascript。这种简单的格式化是XSLT可以直接处理的。

而不是这样做......

<td><xsl:value-of select="Date" /></td>

这样做....

  <td>
    <xsl:choose>
      <xsl:when test="string-length(Date) = 4">
        <xsl:text>01/01/</xsl:text>
        <xsl:value-of select="Date" />
      </xsl:when>
      <xsl:otherwise>
        <xsl:value-of select="substring(Date, 7, 2)" />
        <xsl:text>/</xsl:text>
        <xsl:value-of select="substring(Date, 5, 2)" />
        <xsl:text>/</xsl:text>
        <xsl:value-of select="substring(Date, 1, 4)" />
      </xsl:otherwise>
    </xsl:choose>
  </td>

或许这......

  <td>
    <xsl:choose>
      <xsl:when test="string-length(Date) = 4">
        <xsl:value-of select="concat('01/01/', Date)" />
      </xsl:when>
      <xsl:otherwise>
        <xsl:value-of select="concat(substring(Date, 7, 2), '/', substring(Date, 5, 2), '/', substring(Date, 1, 4))" />
      </xsl:otherwise>
    </xsl:choose>
  </td>