有時,我們可能會希望XML文檔輸出時能對其中內容加上一些統計信息或者如編號什麼的,利用前面的知識就不太容易實現了。今天將介紹兩個新元素<xsl:eval>與<xsl:script>,使我們能輕松處理這個難題。
<xsl:eval>
含義:計算腳本表達式,輸出一個文本字符串。
語法:
<xsl:eval language="language-name">
屬性:
language ── 規定所用腳本語言的名字,可用的屬性有"JavaScript"、"JScript"、"VBScript"、"VBS"等,缺省為"JScript"。
<xsl:script>
含義:聲明全局變量或定義函數。
語法:
<xsl:script language="language-name">
屬性:同<xsl:eval>
示例:
不知大家對於第四期《跟我學XML》中的例子是否還有印象?其中的XML文檔並沒有對簡歷編號,但輸出中卻加上了大寫的羅馬數字序號。今天將再舉一稍為復雜一些的例子:
假如我們編寫一份年終生產統計表,其中需要小計一項,常規的作法是事先將其算出來,現在不必了,我們可以只給出單項統計,顯示時再統計小計一項。請找出《跟我學XML》的第四期,XML文件不必修改,對XSL文件的修改如下:
<?XML version="1.0" encoding="GB2312"?>
<xsl:stylesheet XMLns:xsl="http://www.w3.org/TR/WD-xsl">
<xsl:template match="/">
<Html><HEAD><TITLE>1999年生產統計</TITLE></HEAD>
<BODY><xsl:apply-templates select="document"/></BODY>
</Html>
</xsl:template>
<xsl:template match="document">
<H3>1999年生產統計</H3>
<TABLE border="1" cellspacing="0">
<TH>班組</TH>
<TH>一季度</TH>
<TH>二季度</TH>
<TH>三季度</TH>
<TH>四季度</TH>
<xsl:apply-templates select="report"/>
<TR><TD>小計</TD>
<TD><xsl:eval>total(this,"q1")</xsl:eval></TD>
<TD><xsl:eval>total(this,"q2")</xsl:eval></TD>
<TD><xsl:eval>total(this,"q3")</xsl:eval></TD>
<TD><xsl:eval>total(this,"q4")</xsl:eval></TD>
</TR>
</TABLE>
<xsl:script>
function total(node,q)
{
temp=0;
mark='/document/report/'+q;
v=node.selectNodes(mark);
for(t=v.nextNode();t;t=v.nextNode())
{
temp+=Number(t.text);
}
return temp; //小計值
}
</xsl:script>
</xsl:template>
<xsl:template match="report">
<TR>
<TD><xsl:value-of select="class"/></TD>
<TD><xsl:apply-templates select="q1"/></TD>
<TD><xsl:apply-templates select="q2"/></TD>
<TD><xsl:apply-templates select="q3"/></TD>
<TD><xsl:apply-templates select="q4"/></TD>
</TR>
</xsl:template>
<xsl:template match="q1|q2|q3|q4">
<!--此處測試產量,如小於等於20則添加一STYLE屬性color,其值為red(紅色)-->
<xsl:if test=".[value() $le$ 20]">
<xsl:attribute name="style">color:red</xsl:attribute>
</xsl:if>
<xsl:value-of/>
</xsl:template>
</xsl:stylesheet>
上例在浏覽器中的樣子(IE5.0或更新版本)
說明:
注意到執行結果的變化了嗎?黑體部分為添加部分,注意添加部分分為兩部分,<xsl:script></xsl:script>必須置於</TABLE>之後,切記。
selectNodes() ── 是XMLDOMObject的一個方法,返回文檔中所有滿足條件的結點的集合,條件與< xsl:for-each >和select屬性的取值采用同樣的寫法,可以加篩選、下標等限制,如尋找一季度產量大於等於50的班組:
/document/report/q1[value() $ge$ 50]
以上寫法還有一個更簡單的寫法:
//q1[value()$ge$50]
//表示從根結點出發遍歷所有結點,尋找滿足條件的結點,如果文檔內有同名但意義不同的結點則不能用此種方法,非不得已不建議使用。以此為例,如果希望統計年總產量,則可以下述字符串尋找結點(建議使用最後一種,此種描述將精確找到需要匯總的數據):
//*[value()$gt$0] 或 //(q1|q2|q3|q4) 或 /document/report/(q1|q2|q3|q4)
nextNode() ── 返回結點集中的下一個結點
Number() ── 將提供的參數轉換為數值
下期介紹XSL函數2,用於<xsl:script>及<xsl:eval>中,以及<xsl:if>和<xsl:when>的expr屬性。建議讀者熟悉JavaScript、JScript、VBScript中至少一種,否你能用XSL完成的工作將十分有限。由於篇幅關系,此處不作詳細介紹。