跟我学XSL(四)
测试模式XML技术的优势之一就在于数据输出的可选择性,即选择需要的数据输出。前面我们所讲到的选择模式语句:$$#@60;xsl:for-each$$#@62;、$$#@60;xsl:value-of$$#@62;及$$#@60;xsl:apply-template$$#@62;只是简单的选取通过”/”符号层层到达的节点,如果我们对XML数据不需要全部输出,而只需要其中的满足某条件的部分数据,“萝卜青菜、各取所需“,那么条件判断$$#@60;xsl:if$$#@62;与多条件判断$$#@60;xsl:choose$$#@62;及$$#@60;xsl:when$$#@62;则迎合了这种需要,如果你对程序设计熟悉的话,会觉得它们似曾相识。
XSL中的IF,首先,介绍XSL元素$$#@60;xsl:if$$#@62;的语法结构:
$$#@60;xsl:if$$#@62;
语法:
$$#@60;xsl:if expr=“script-expression“ language=“language-name“ test=“pattern“$$#@62;
属性:
expr ──脚本语言表达式,计算结果为“真”或“假”;如果结果为“真”,且通过test,则在输出中显示其中内容(可省略此项属性)。
language ──expr属性中表达式的脚本语言类型,其取值与HTML标记SCRIPT的LANGUAGE属性的取值相同,缺省为“JScript”test ──源数据测试条件。
示例:
此处以一份报表为例,文件名为report.xml,其内容如下:
$$#@60;?xml version=“1.0“ encoding=“GB2312“?$$#@62;
$$#@60;?xml:stylesheet type=“text/xsl“ href=http://www.blue1000.com/article/“report.xsl“?$$#@62;
$$#@60;document$$#@62;
$$#@60;report$$#@62;
$$#@60;class$$#@62;
甲班
$$#@60;/class$$#@62;$$#@60;q1$$#@62;50$$#@60;/q1$$#@62;$$#@60;q2$$#@62;70$$#@60;/q2$$#@62;
$$#@60;q3$$#@62;30$$#@60;/q3$$#@62;$$#@60;q4$$#@62;10$$#@60;/q4$$#@62;$$#@60;/report$$#@62;
$$#@60;report$$#@62;$$#@60;class$$#@62;
乙班
$$#@60;/class$$#@62;$$#@60;q1$$#@62;20$$#@60;/q1$$#@62;$$#@60;q2$$#@62;30$$#@60;/q2$$#@62;
$$#@60;q3$$#@62;40$$#@60;/q3$$#@62;$$#@60;q4$$#@62;50$$#@60;/q4$$#@62;$$#@60;/report$$#@62;
$$#@60;report$$#@62;$$#@60;class$$#@62;
丙班
$$#@60;/class$$#@62;$$#@60;q1$$#@62;70$$#@60;/q1$$#@62;$$#@60;q2$$#@62;40$$#@60;/q2$$#@62;
$$#@60;q3$$#@62 $$#@60;/q3$$#@62;$$#@60;q4$$#@62;10$$#@60;/q4$$#@62;$$#@60;/report$$#@62;
$$#@60;/document$$#@62;
我们采用XSL模板结合今天所学的$$#@60;xsl:if$$#@62;,为其编写一个XSL文档,要求季度产量小于等于20的用红色表示,文件名为report.xsl,内容如下:
$$#@60;?xml version=“1.0“ encoding=“GB2312“?$$#@62;
$$#@60;xsl:stylesheet xmlns:xsl=“http://www.w3.org/TR/WD-xsl“$$#@62;
$$#@60;xsl:template match=“/“$$#@62;
$$#@60;HTML$$#@62;$$#@60;HEAD$$#@62;$$#@60;TITLE$$#@62;1999年生产统计$$#@60;/TITLE$$#@62;$$#@60;/HEAD$$#@62;
$$#@60;BODY$$#@62;$$#@60;xsl:apply-templates select=“document ;“/$$#@62;$$#@60;/BODY$$#@62;
$$#@60;/HTML$$#@62;
$$#@60;/xsl:template$$#@62;
$$#@60;xsl:template match=“document“$$#@62;
$$#@60;H3$$#@62;1999年生产统计$$#@60;/H3$$#@62;
$$#@60;TABLE border=“1“ cellspacing=“0“$$#@62;
$$#@60;TH$$#@62;班组$$#@60;/TH$$#@62;$$#@60;TH$$#@62;
一季度
$$#@60;/TH$$#@62;$$#@60;TH$$#@62;
二季度
$$#@60;/TH$$#@62;
$$#@60;TH$$#@62;
三季度
$$#@60;/TH$$#@62;$$#@60;TH$$#@62;
四季度
$$#@60;/TH$$#@62;
$$#@60;xsl:apply-templates select=“report“/$$#@62;
$$#@60;/TABLE$$#@62;
$$#@60;/xsl:template$$#@62;
$$#@60;xsl:template match=“report“$$#@62;
$$#@60;TR$$#@62;
$$#@60;TD$$#@62;$$#@60;xsl:value-of select=“class“/$$#@62;$$#@60;/TD$$#@62;
$$#@60;TD$$#@62;$$#@60;xsl:apply-templates select=“q1“/$$#@62;$$#@60;/TD$$#@62;
$$#@60;TD$$#@62;$$#@60;xsl:apply-templates select=“q2“/$$#@62;$$#@60;/TD$$#@62;
$$#@60;TD$$#@62;$$#@60;xsl:apply-templates select=“q3“/$$#@62;$$#@60;/TD$$#@62;
$$#@60;TD$$#@62;$$#@60;xsl:apply-templates select=“q4“/$$#@62;$$#@60;/TD$$#@62;
$$#@60;/TR$$#@62;
$$#@60;/xsl:template$$#@62;
$$#@60;xsl:template match=“q1|q2|q3|q4“$$#@62;
$$#@60;!--此处测试产量,如小于等于20则添加一STYLE属性color,其值为red(红色)--$$#@62;
$$#@60;xsl:if test=“.[value() $$le$$ 20]“$$#@62;
$$#@60;xsl:attribute name=“style“$$#@62;color:red$$#@60;/xsl:attribute$$#@62;
$$#@60;/xsl:if$$#@62;
$$#@60;xsl:value-of/$$#@62;
$$#@60;/xsl:template$$#@62;
$$#@60;/xsl:stylesheet$$#@62;
说明:
q1|q2|q3|q4 ──标记q1、q2、q3、q3均用此模板确定输出
$$le$$ ──是关系运算符中的“小于等于”,其它关系有小于($$lt$$)、大于($$gt$$)、大于等于($$ge$$)、等于($$eq$$)、不等于($$ne$$)等
. ──表示引用当前标记
[ ] ──表示筛选,只有满足筛选条件的标记才能被选取
value() ──XSL函数,其他常用XSL函数有text()、end()、index()等。
下期,我们将学习XSL的另外三个元素,可对同一数据进行多次测试,根据不同条件产生相应输出。
 
 
发表评论