本课学习在XSL中使用脚本。
<xsl:eval>
含义:计算脚本表达式,输出一个文本字符串
语法:<xsl:eval language="language-name">
属性:
language ── 规定所用脚本语言的名字,可用的属性有“JavaScript”、“JScript”、“VBScript”、“VBS”等,缺省为“JScript”。
<xsl:script>
含义:声明全局变量或定义函数。
语法:<xsl:script language="language-name">
属性:同< xsl:eval >
示例:
假如我们编写一份年终生产统计表,其中需要小计一项,常规的作法是事先将其算出来,现在不必了,我们可以只给出单项统计,显示时再统计小计一项。
report.xml:
<?xml version="1.0" encoding="GB2312"?>
<?xml:stylesheet type="text/xsl" href="report.xsl"?>
<document>
<report>
<class>
甲班
</class><q1>50</q1><q2>70</q2>
<q3>30</q3><q4>10</q4></report>
<report><class>
乙班
</class><q1>20</q1><q2>30</q2>
<q3>40</q3><q4>50</q4></report>
<report><class>
丙班
</class><q1>70</q1><q2>40</q2>
<q3>20</q3><q4>10</q4></report>
</document>
report.xsl修改如下:
< xsl:template match="document" >
……
< 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: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:eval>
含义:计算脚本表达式,输出一个文本字符串
语法:<xsl:eval language="language-name">
属性:
language ── 规定所用脚本语言的名字,可用的属性有“JavaScript”、“JScript”、“VBScript”、“VBS”等,缺省为“JScript”。
<xsl:script>
含义:声明全局变量或定义函数。
语法:<xsl:script language="language-name">
属性:同< xsl:eval >
示例:
假如我们编写一份年终生产统计表,其中需要小计一项,常规的作法是事先将其算出来,现在不必了,我们可以只给出单项统计,显示时再统计小计一项。
report.xml:
<?xml version="1.0" encoding="GB2312"?>
<?xml:stylesheet type="text/xsl" href="report.xsl"?>
<document>
<report>
<class>
甲班
</class><q1>50</q1><q2>70</q2>
<q3>30</q3><q4>10</q4></report>
<report><class>
乙班
</class><q1>20</q1><q2>30</q2>
<q3>40</q3><q4>50</q4></report>
<report><class>
丙班
</class><q1>70</q1><q2>40</q2>
<q3>20</q3><q4>10</q4></report>
</document>
report.xsl修改如下:
< xsl:template match="document" >
……
< 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: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() ── 将提供的参数转换为数值