现在的位置: 首页 > 综合 > 正文

跟我学XSL(八)

2013年05月15日 ⁄ 综合 ⁄ 共 1184字 ⁄ 字号 评论关闭

有时,我们可能会希望XML文档输出时能对其中内容加上一些统计信息或者如编号什么的,利用前面的知识就不太容易实现了。今天将介绍两个新元素与,使我们能轻松处理这个难题。

含义:

计算脚本表达式,输出一个文本字符串

语法:

属性:

language ── 规定所用脚本语言的名字,可用的属性有“JavaScript”、“JScript”、“VBScript”、“VBS”等,缺省为“JScript”。

含义:

声明全局变量或定义函数。

语法:

属性:

示例:

  不知大家对于第四期《跟我学XML》中的例子是否还有印象?其中的XML文档并没有对简历编号,但输出中却加上了大写的罗马数字序号。今天将再举一稍为复杂一些的例子:

  假如我们编写一份年终生产统计表,其中需要小计一项,常规的作法是事先将其算出来,现在不必了,我们可以只给出单项统计,显示时再统计小计一项。请找出《跟我学XML》的第五期,XML文件不必修改,对XSL文件的修改如下:

……

……

小计

total(this,"q1")

total(this,"q2")

total(this,"q3")

total(this,"q4")

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; //小计值

}

说明:

  黑体部分为添加部分,注意添加部分分为两部分,必须置于之后,切记。

selectNodes() ── 是XMLDOMObject的一个方法,返回文档中所有满足条件的结点的集合,条件与和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,用于及中,以及和的expr属性。建议读者熟悉JavaScript、JScript、VBScript中至少一种,否你能用XSL完成的工作将十分有限。由于篇幅关系,此处不作详细介绍。

 

(目前就找到这些,以后再补充)

抱歉!评论已关闭.