打印

XSLT2.0新特性分析

本帖已经被作者加入个人空间

XSLT2.0新特性分析

作者: ,  出处:IT专家网社区, 责任编辑: 叶江, 
2007-03-23 10:25
  对于XSLT 2.0中的新特性,本文将除开那些现在无益的特性,主要讨论那些能够立即满足应用程序开发需求的特性……

  分组

  我发现,似乎每次我开始写一个XSL式样表,随后就需要用到分组信息。这种需求可能是由于某种对数据进行分类,使其更具可读性的深层次要求所引起的;或者只是由于我神经过敏!可能制定这些要求的人以前在国家狩猎委员会工作:“你可以钓一只鲑鱼和六磅其它供垂钓的鱼或一磅供垂钓的鱼和一只鲑鱼。”如果你曾经看过有关钓鱼方面的法律,你就会明白我的意思。

  在XSLT 1.0中,使用分组就像在冒险,这些事情需要不断实践,像是在洞穴探险时不被Grue怪吃掉。XSLT 1.0中的首选分组方法叫做Meunchian分组,它由Oracle的Steve Meunch开发。

  它的工作方式如下:编码一个xsl:key元素,指定将会用作关键字的元素或属性,以及关键字提交的元素。比较每个关键字的第一个实例提交的元素的ID和文档中的相同元素ID即可完成分组。如果两个ID匹配,则节点相同。这保证式样表中每个关键字只处理一次,并可以处理含有那个关键字值的所有元素。

  下面列出一个XML样本文档和一个XSLT 1.0 Muenchian分组实例,如列表A和B。

  列表A——XML样本文档

<?xml version="1.0" encoding="UTF-8"?>
<world>
<country name="Canada" continent="North America">
<city>Toronto</city>
<city>Vancouver</city>
</country>
<country name="Jamaica" continent="North America">
<city>Kingston</city>
<city>Ocho Rios</city>
</country>
<country name="United States" continent="North America">
<city>Allentown</city>
<city>Mobile</city>
</country>
<country name="United Kingdom" continent="Europe">
<city>London</city>
<city>Dundee</city>
</country>
<country name="France" continent="Europe">
<city>aris</city>
<city>Nice</city>
</country>
<country name="Japan" continent="Asia">
<city>Tokyo</city>
<city>Osaka</city>
</country>
</world>

  列表B——XSLT 1.0 Muenchian分组

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:fo="http://www.w3.org/1999/XSL/Format">
<xsl:key name="keyContinent" match="//country" use="@continent"/>
<xsl:template match="/">
<xsl:element name="world">
<xsl:for-each select="//country[generate-id(.) = generate-id(ke('keyContinent',@continent)[1])]">
<xsl:sort select="@continent" data-type="text" order="ascending"/>
<xsl:variable name="continent" select="@continent"/>
<xsl:apply-templates select="//country[@continent = $continent]" mode="group">
<xsl:sort select="@name" data-type="text" order="ascending"/>
</xsl:apply-templates>
</xsl:for-each>
</xsl:element>
</xsl:template>
<xsl:template match="*" mode="group">
<xsl:copy-of select="."/>
</xsl:template>
</xsl:stylesheet>

  在XSLT 2.0中,分组方法有了一些改变,但应该指出的是,Meunchian分组方法依然可用。所不同的是,Meunchian分组为可选方法,因为XSLT 2.0中内置了分组功能,因此实际上不必再使用Meunchian分组。开发者可以使用xsl:for-each-group来代替它,如列表C所示。

共4页。 1 2 3 4 :

TOP

作者: ,  出处:IT专家网社区, 责任编辑: 叶江, 
2007-03-23 10:25
  对于XSLT 2.0中的新特性,本文将除开那些现在无益的特性,主要讨论那些能够立即满足应用程序开发需求的特性……

  列表C——XSLT 2.0中的分组

<?xml version="1.0" encoding="UTF-8"?>

<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:fo="http://www.w3.org/1999/XSL/Format" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:fn="http://www.w3.org/2005/xpath-functions" xmlns:xdt="http://www.w3.org/2005/xpath-datatypes">

<xsl:template match="/">
<xsl:element name="world">
<xsl:for-each-group select="//country" group-by="@continent">
<xsl:sort select="@continent" data-type="text" order="ascending"/>
<xsl:variable name="continent" select="@continent"/>
<xsl:apply-templates select="//country[@continent = $continent]" mode="group">
<xsl:sort select="@name" data-type="text" order="ascending"/>
</xsl:apply-templates>
</xsl:for-each-group>
</xsl:element>
</xsl:template>
<xsl:template match="*" mode="group">
<xsl:copy-of select="."/>
</xsl:template>
</xsl:stylesheet>

  虽然这些分组方法各不相同,但它们的最终结果是一样的,如列表D所示。

  列表D——分组结果

<?xml version="1.0" encoding="UTF-8"?>
<world>
<country name="Japan" continent="Asia">
<city>Tokyo</city>
<city>Osaka</city>
</country>
<country name="France" continent="Europe">
<city>aris</city>
<city>Nice</city>
</country>
<country name="United Kingdom" continent="Europe">
<city>London</city>
<city>Dundee</city>
</country>
<country name="Canada" continent="North America">
<city>Toronto</city>
<city>Vancouver</city>
</country>
<country name="Jamaica" continent="North America">
<city>Kingston</city>
<city>Ocho Rios</city>
</country>
<country name="United States" continent="North America">
<city>Allentown</city>
<city>Mobile</city>
</country>
</world>

共4页。 9 1 2 3 4 :

TOP

作者: ,  出处:IT专家网社区, 责任编辑: 叶江, 
2007-03-23 10:25
  对于XSLT 2.0中的新特性,本文将除开那些现在无益的特性,主要讨论那些能够立即满足应用程序开发需求的特性……

  多文档输出

  在使用XSLT 1.0时,我经常遇到式样表输出限制。我指的是文档输出问题,它一次只允许输出一个文档。这表示有必要在结果文档生成时进行处理。

  以列表A中的XML文档为例,假设我们要把它分成几个XML文档,每个国家一个。过去必须用选择的语言编写一些代码建立单独的XML文档。XSLT 2.0改变了这种做法。

  现在XSLT 2.0使用xsl:result-document元素,它与xslutput元素结合生成几个输出文档。有趣的是,使用方法属性,不同的xslutput文档可以用来生成不同的文档类型。列表E中的式样表说明了使用这种特性的一种可能方法,列表F-L中的XML文档为处理结果。

  列表E——在XSLT 2.0中生成多个输出文档

<?xml version="1.0" encoding="UTF-8"?>

<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:fo="http://www.w3.org/1999/XSL/Format" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:fn="http://www.w3.org/2005/xpath-functions" xmlns:xdt="http://www.w3.org/2005/xpath-datatypes">

<xslutput name="xml" method="xml"/>
<xsl:template match="/">
<xsl:apply-templates select="//country"/>
</xsl:template>
<xsl:template match="country">
<xsl:variable name="name" select="concat(@name,'.xml')"/>
<xsl:result-document href="" format="xml">
<xsl:copy-of select="."/>
</xsl:result-document>
</xsl:template>
</xsl:stylesheet>

  列表F -- Canada.xml

<?xml version="1.0" encoding="UTF-8"?>
<country name="Canada" continent="North America">
<city>Toronto</city>
<city>Vancouver</city>
</country>

  列表H -- Jamiaca.xml

<?xml version="1.0" encoding="UTF-8"?>
<country name="Jamaica" continent="North America">
<city>Kingston</city>
<city>Ocho Rios</city>
</country>

共4页。 9 1 2 3 4 :

TOP

作者: ,  出处:IT专家网社区, 责任编辑: 叶江, 
2007-03-23 10:25
  对于XSLT 2.0中的新特性,本文将除开那些现在无益的特性,主要讨论那些能够立即满足应用程序开发需求的特性……

  列表I -- United States.xml

<?xml version="1.0" encoding="UTF-8"?>
<country name="United States" continent="North America">
<city>Allentown</city>
<city>Mobile</city>
</country>

  列表J -- United Kingdom.xml

<?xml version="1.0" encoding="UTF-8"?>
<country name="United Kingdom" continent="Europe">
<city>London</city>
<city>Dundee</city>
</country>

  列表K -- France.xml

<?xml version="1.0" encoding="UTF-8"?>
<country name="France" continent="Europe">
<city>aris</city>
<city>Nice</city>
</country>

  列表 L -- Japan.xml

<?xml version="1.0" encoding="UTF-8"?>
<country name="Japan" continent="Asia">
<city>Tokyo</city>
<city>Osaka</city>
</country>

  其它特性

  除已经列举的特性外,我的最喜爱特性列表中还有其它一些特性。第一个是XPath 2.0支持。作为一个XML爱好者,我期待着试用这些新特性和XPath 2.0的功能。第二个特性,XQuery 1.0,可帮助其他人更易于理解XSLT。XQuery 1.0有望帮助那些对XPath“过敏”的用户使用XSLT 2.0。

  应用XSLT 2.0

  不幸的是,如果你对试用XSLT 2.0版本的新特性感兴趣,当前只能使用少数几个处理器。第一个为Michael Kay的Saxon处理器,如果你希望遵从万维网联盟的推荐,这个开源XSLT处理器为你提供了一个选择。另一个是Altova的XMLSpy处理器,它是我见过的速度最快的XML编辑器。它们的网站提供这个处理器的30天试用版本。唯一的问题是,30天试用到期后,你就想购买这个处理器了!

共4页。 9 1 2 3 4

TOP

当前时区 GMT+8, 现在时间是 2008-12-3 06:03
新ICP备05002317号
Powered by Discuz! 6.0.0 © 2001-2007 Comsenz Inc.
Processed in 0.059103 second(s), 7 queries, Gzip enabled
TOP
清除 Cookies - 联系我们 - 网络游戏代理 - Archiver - - WAP
Designed By Discuz! 百宝箱论坛