跟我学XSL(四)

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

发表回复

   


  通知楼主
暂无回复!

猜你喜欢

刷新 换一批