在之前的XML与XSLT的文章中我曾经提到过使用XSL可以对XML文件中的数据进行查询和筛选的操作,但并没有给出具体的实例,下面我将通过自己实际工作中使用到的代码针对XSLT中的<xsl:Choose>和<xsl:for-each>两个元素进行简单讲述。
在我目前负责的一个项目中使用用XML做为配置文件。其内容如下所示。























































































这个配置文件中主要记录了三部分的信息,一部分是表单的基本信息,一部分是表单中的字段信息,还有一部分是对应查询,插入,删除和更新的SQL语句。在IE中查看这个配置文件时,其会使用自带的XML解析器对该文件进行解析,看到的是一个树型的数据,对我而言这种查看方式并不方便,于是我自己动手为其编写了一个XSL转换文件。
大家可以看到这个配置文件中有个FieldList结点,这个结点下又有若干个Field子结点,Field结点会依据其属性Control的值决定其下会出现哪些子结点以及哪些属性。我们在进行转换时就需要用到<xsl:for-each>元素对FieldList结点下的子结点进行遍历,同时还需要用到<xsl:choose>元素来判断Field结点Control属性值决定下一步动作。下面就是针对FieldList结点的XSL文件片断。




















































我们首先在样式中定义了一个表格做为FieldList的显示容器,当表头定义结束后,就开始遍历其子结点,每个一子结点Field对应着表中的一行。<xsl:for-each>很像程序设计语言中的循环语句,它会逐一访问每一个子结点,直至全部访问完毕。


































每个单元格的内容都是使用<xsl:value-of select="ChildNodeName">或是<xsl:value-of select="@AttributeName">元素直接读取XML文件中的内容,唯一需要单独处理的就是有两个单元格要依据结点Control属性值的不同读取不同元素的值进行填充显示,这里就用到了<xsl:choose>元素。







<xsl:choose>元素的用法很像程序设计语言中的Case语句。使用<xsl:when test="">进行条件判断,使用<xsl:otherwise>作为默认处理。需要注意的是在test中进行条件判断时不能直接使用双引号("),而是要使用转义符"代替。这里我们先判断Control属性值是否为“Textarea”,如果是,则选择子结点ControlAttribute的Cols属性输出,否则选择子结点ControlAttribute的Size属性输出。
以上仅是一家之言,还望斧正。
版权声明:本文为博主原创文章,未经博主允许不得转载。
相关推荐
- **XML和XSLT**:用于数据交换和处理,XSLT则用于转换XML数据以适应不同的显示需求。 - **XMLHttpRequest**:核心组件之一,用于异步读取服务器数据,无需等待数据返回即可继续执行后续代码。 #### 二、现状与问题...
XML作为数据交换格式,可以与服务器之间交换结构化的数据,而XSLT(可扩展样式表语言转换)则用于将XML文档转换为其他格式,如HTML。 在实际应用开发中,可以使用各种AJAX开发框架来简化开发过程,比如Prototype、...
5. **XSLT**:虽然不是libxml的核心部分,但libxml可以与其他库(如libxslt)配合,实现XML到XML或HTML的转换。 在ASIHTTPRequest和libxml结合使用时,通常会在请求完成时触发一个回调,然后在回调中利用libxml对...
- `serializer.jar`:这个JAR文件是Xalan XSLT处理器的一部分,用于将XML转换成其他格式,如HTML或文本。 - `mailapi.jar`:这可能是JavaMail API的一个部分,尽管在标准JavaMail分发中通常不包含单独的`mailapi....
XML处理组件是CIS中的另一个亮点,它提供了解析、创建、修改XML文档的能力,同时支持XPath查询和XSLT转换,使得开发者在处理XML数据时得心应手。 除了以上主要组件,CIS还包含了许多其他实用的互联网协议支持,如...
5. **XML 处理**:Chilkat 可以解析、修改和生成 XML 文档,支持 XPath 查询和 XSLT 转换。 6. **日期和时间处理**:Chilkat 包含了丰富的日期和时间处理功能,可以进行时间的转换、比较和格式化。 7. **网络通信*...
eStar MQ作为易达讯的消息中间件产品,支持多种消息模式,包括消息队列、消息订阅和发布、消息请求和应答,同时具备信息转换功能,如XSLT映射。为了确保数据传输的可靠性,它提供了消息存储、传输确认、数据压缩、...