新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   >>中国XML论坛<<     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 本版讨论XSL,XSLT,XSL-FO,CSS等技术
    [返回] 中文XML论坛 - 专业的XML技术讨论区XML.ORG.CN讨论区 - XML技术『 XSL/XSLT/XSL-FO/CSS 』 → XSL简明教程(1)XSL入门[转帖] 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 9576 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: XSL简明教程(1)XSL入门[转帖] 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     zxsaso 美女呀,离线,快来找我吧!
      
      
      等级:大二(研究汇编)
      文章:37
      积分:223
      门派:XML.ORG.CN
      注册:2006/7/18

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给zxsaso发送一个短消息 把zxsaso加入好友 查看zxsaso的个人资料 搜索zxsaso在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 引用回复这个贴子 回复这个贴子 查看zxsaso的博客楼主
    发贴心情 XSL简明教程(1)XSL入门[转帖]

    一. XSL入门

    1.XSL---XML的样式表

    HTML网页使用预先确定的标识(tags),这就是说所有的标记都有明确的含义,例如<p>是另起一行<h1>是标题字体。所有的浏览器都知道如何解析和显示HTML网页。
    然而,XML没有固定的标识,我们可以建立我们自己需要的标识,所以浏览器不能自动解析它们,例如<table>可以理解为表格,也可以理解为桌子。由于XML的可扩展性,使我们没有一个标准的办法来显示XML文档。
    为了控制XML文档的显示,我们有必要建立一种机制,CSS就是其中的一种,但是XSL(eXtensible Stylesheet Language)是显示XML文档的首选样式语言,它比CSS更适合于XML。

    2.XSL --- 不仅仅是一种样式表

    XSL由两部分组成:

    一是转化XML文档;二是格式化XML文档。

    如果你不理解这个意思,可以这样想:XSL是一种可以将XML转化成HTML的语言,一种可以过滤和选择XML数据的语言,一种能够格式化XML数据的语言。(比如用红色显示负数。)

    3.XSL --- 它能做什么?

    XSL可以被用来定义XML文档如何显示,可以将XML文档转换成能被浏览器识别的HTML文件,通常的,XSL是通过将每一个XML元素"翻译"为HTML元素,来实现这种转换的。

    XSL能够向输出文件里添加新的元素,或则移动元素。XSL也能够重新排列或者索引数据,它可以检测并决定哪些元素被显示,显示多少。

    4.XSL在IE5中的显示

    注意:IE5.0中,并不能完全兼容W3C组织发布的最新XSL标准。因为IE5.0是在XSL标准最终确定以前发布的。微软已经承诺在IE5.5中修正。


       收藏   分享  
    顶(0)
      




    ----------------------------------------------
    什么时候毛毛虫可以变蝴蝶?!

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/8/17 17:04:00
     
     zxsaso 美女呀,离线,快来找我吧!
      
      
      等级:大二(研究汇编)
      文章:37
      积分:223
      门派:XML.ORG.CN
      注册:2006/7/18

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给zxsaso发送一个短消息 把zxsaso加入好友 查看zxsaso的个人资料 搜索zxsaso在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 引用回复这个贴子 回复这个贴子 查看zxsaso的博客2
    发贴心情 
    XSL简明教程(5)XSL的索引
    原著:Jan Egil Refsnes 翻译:阿捷


    五. XSL 的索引


    如果我需要将元素的显示按一定的顺序排列,应该如何建立XSL的索引呢?

    我们还是来看前面的例子,还是这段代码:


    <xml version="1.0" encoding="ISO8859-1" >

    <CATALOG>

    <CD>

    <TITLE>Empire Burlesque</TITLE>

    <ARTIST>Bob Dylan</ARTIST>

    <COUNTRY>USA</COUNTRY>

    <COMPANY>Columbia</COMPANY>

    <PRICE>10.90</PRICE>

    <YEAR>1985</YEAR>

    </CD>

    .

    .

    .


    当XML文档被转换成HTML文件,索引应该同时建立。简单的办法就是给你的for-each元素增加一个order-by属性,就象这样:

    <xsl:for-each select="CATALOG/CD" order-by="+ ARTIST">

    order-by属性带有一个"+"或者"-" 的符号,用来定义索引的方式,是升序还是降序排列。符号后面的名字就是要索引的关键字。

    例如(cd_catalog_sort.xsl):

    <xml version=′1.0′>

    <xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/WD-xsl">

    <xsl:template match="/">

    <html>

    <body>

    <table border="2" bgcolor="yellow">

    <tr>

    <th>Title</th>

    <th>Artist</th>

    </tr>

    <xsl:for-each select="CATALOG/CD" order-by="+ ARTIST">

    <tr>

    <td><xsl:value-of select="TITLE"/></td>

    <td><xsl:value-of select="ARTIST"/></td>

    </tr>

    </xsl:for-each>

    </table>

    </body>

    </html>

    </xsl:template>

    </xsl:stylesheet>


    最后,我们用下面的HTML代码来显示索引结果,你可以自己尝试一下。

    <html>

    <body>

    <script language="javascript">

    // Load XML

    var xml = new ActiveXObject("Microsoft.XMLDOM")

    xml.async = false

    xml.load("cd_catalog.xml")


    // Load the XSL

    var xsl = new ActiveXObject("Microsoft.XMLDOM")

    xsl.async = false

    xsl.load("cd_catalog_sort.xsl")


    // Transform

    document.write(xml.transformNode(xsl))

    </script>


    </body>

    </html>

    ----------------------------------------------
    什么时候毛毛虫可以变蝴蝶?!

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/8/19 16:07:00
     
     zxsaso 美女呀,离线,快来找我吧!
      
      
      等级:大二(研究汇编)
      文章:37
      积分:223
      门派:XML.ORG.CN
      注册:2006/7/18

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给zxsaso发送一个短消息 把zxsaso加入好友 查看zxsaso的个人资料 搜索zxsaso在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 引用回复这个贴子 回复这个贴子 查看zxsaso的博客3
    发贴心情 
    XSL简明教程(6)XSL过滤和查询
    原著:Jan Egil Refsnes 翻译:阿捷


    六. XSL的过滤和查询


    如果我们希望只显示满足一定的条件的XML数据应该怎么做呢?还是上面的例子代码,我们只需要在xsl:for-each元素的select属性中加入参数就可以,类似:

    <xsl:for-each select="CATALOG/CD[ARTIST=′Bob Dylan′]">

    参数的逻辑选择有:

    = (等于)

    =! (不等于)

    &LT& 小于

    &GT& 大于等于


    和前面同样的
    例子(cd_catalog_sort.xsl):


    <xml version=′1.0′>

    <xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/WD-xsl">

    <xsl:template match="/">

    <html>

    <body>

    <table border="2" bgcolor="yellow">

    <tr>

    <th>Title</th>

    <th>Artist</th>

    </tr>

    <xsl:for-each select="CATALOG/CD[ARTIST=′Bob Dylan′]">

    <tr>

    <td><xsl:value-of select="TITLE"/></td>

    <td><xsl:value-of select="ARTIST"/></td>

    </tr>

    </xsl:for-each>

    </table>

    </body>

    </html>

    </xsl:template>

    </xsl:stylesheet>


    你可以自己测试一下,看到的结果有什么不同。

    简明教程共六部分 转贴完毕

    ----------------------------------------------
    什么时候毛毛虫可以变蝴蝶?!

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/8/19 16:10:00
     
     loos 美女呀,离线,快来找我吧!
      
      
      等级:大一(高数修炼中)
      文章:33
      积分:179
      门派:XML.ORG.CN
      注册:2006/4/11

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给loos发送一个短消息 把loos加入好友 查看loos的个人资料 搜索loos在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 引用回复这个贴子 回复这个贴子 查看loos的博客4
    发贴心情 
    十分有帮助,谢谢
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/8/19 20:59:00
     
     zxsaso 美女呀,离线,快来找我吧!
      
      
      等级:大二(研究汇编)
      文章:37
      积分:223
      门派:XML.ORG.CN
      注册:2006/7/18

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给zxsaso发送一个短消息 把zxsaso加入好友 查看zxsaso的个人资料 搜索zxsaso在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 引用回复这个贴子 回复这个贴子 查看zxsaso的博客5
    发贴心情 
    XSL简明教程(3)在客户端的实现[转帖]

    XSL简明教程(3)在客户端的实现
    资料来源 :网络资料

    原著:Jan Egil Refsnes 翻译:阿捷


    三. XSL--在客户端的实现


    1.JavaScript解决方案

    在上面的章节中我们已经解释了XSL是如何将XML转换成HTML文件。方法就是在XML文档的头部加入一个XSL样式表信息,然后让浏览器执行转换过程。

    这种方法在大部分情况下都做得很好,但是在不支持XML的浏览器中就无法正确显示了。

    一个更好的更全面的解决方案是使用Javascript来实现XML到HTML的转换。但是使用JavaScript必须得到以下功能支持:

    a.允许Javascript代替浏览器进行细节检测;

    b.根据不同的需要和不同的浏览器使用不同的样式表。

    对于XSL来说这是完全可行的。设计XSL的目标之一就是允许将一种格式转换成另一种格式,支持不同的浏览器,支持不同的用户需求。未来的浏览器的重要任务就是在客户端执行XSL的转换工作。


    2.一个具体的实例

    下面是我们上面提到的一个XML文档(cd_catalog.xml)例子的部分代码:

    <xml version="1.0" encoding="ISO8859-1" >

    <CATALOG>

    <CD>

    <TITLE>Empire Burlesque</TITLE>

    <ARTIST>Bob Dylan</ARTIST>

    <COUNTRY>USA</COUNTRY>

    <COMPANY>Columbia</COMPANY>

    <PRICE>10.90</PRICE>

    <YEAR>1985</YEAR>

    </CD>

    .

    .

    .

    下面是完整的XSL文件(cd_catalog.xsl):


    <xml version=′1.0′>

    <xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/WD-xsl">

    <xsl:template match="/">

    <html>

    <body>

    <table border="2" bgcolor="yellow">

    <tr>

    <th>Title</th>

    <th>Artist</th>

    </tr>

    <xsl:for-each select="CATALOG/CD">

    <tr>

    <td><xsl:value-of select="TITLE"/></td>

    <td><xsl:value-of select="ARTIST"/></td>

    </tr>

    </xsl:for-each>

    </table>

    </body>

    </html>

    </xsl:template>

    </xsl:stylesheet>


    注意,现在XML文件还没有加入XSL样式表,还没有被转换成HTML文件。

    下面是用JavaSript来实现最后转换的HTML代码:


    <html>

    <body>

    <script language="javascript">

    // Load XML

    var xml = new ActiveXObject("Microsoft.XMLDOM")

    xml.async = false

    xml.load("cd_catalog.xml")


    // Load the XSL

    var xsl = new ActiveXObject("Microsoft.XMLDOM")

    xsl.async = false

    xsl.load("cd_catalog.xsl")


    // Transform

    document.write(xml.transformNode(xsl))

    </script>


    </body>

    </html>


    上面代码中使用了Javascript,如果你不知道如何写JavaScript,您最好专门学习一下。

    第一段代码建立一个Microsoft Parser(XMLDOM)解析的对象,并将XML文档读入内存;第二段代码建立另外一个对象并导入XSL文档;最后一行代码将XML文档用XSL文档转换,并将结果输出到HTML文件中。

    ----------------------------------------------
    什么时候毛毛虫可以变蝴蝶?!

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/8/19 21:52:00
     
     zxsaso 美女呀,离线,快来找我吧!
      
      
      等级:大二(研究汇编)
      文章:37
      积分:223
      门派:XML.ORG.CN
      注册:2006/7/18

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给zxsaso发送一个短消息 把zxsaso加入好友 查看zxsaso的个人资料 搜索zxsaso在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 引用回复这个贴子 回复这个贴子 查看zxsaso的博客6
    发贴心情 
    XSL简明教程(4)在服务器端的实现[转帖]

    资料来源 :网络资料

    原著:Jan Egil Refsnes 翻译:阿捷


    四: XSL --- 在服务器端的实现


    1.兼容所有的浏览器

    在上面一章我们介绍了可以通过JavaScript调用浏览器的XML parser(解析软件)来转换XML文档。但是这个方案依然有个问题:如果浏览器没有XML
    parser插件怎么办?(注:IE5内自带XML parser)

    为了使我们的XML数据能被所有的浏览器正确显示,我们不得不在服务器端将XML转换成纯HTML代码,再输出给浏览器。

    这也是使用XSL的另一个好处。在服务器端将一种格式转换为另一种格式也是XSL的设计目标之一。

    同样,转换工作也将成为未来服务器段的主要工作。


    2.一个具体实例

    下面是我们上面提到的一个XML文档(cd_catalog.xml)例子的部分代码:

    <xml version="1.0" encoding="ISO8859-1" >

    <CATALOG>

    <CD>

    <TITLE>Empire Burlesque</TITLE>

    <ARTIST>Bob Dylan</ARTIST>

    <COUNTRY>USA</COUNTRY>

    <COMPANY>Columbia</COMPANY>

    <PRICE>10.90</PRICE>

    <YEAR>1985</YEAR>

    </CD>

    .
    下面是完整的XSL文件(cd_catalog.xsl):


    <xml version=′1.0′>

    <xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/WD-xsl">

    <xsl:template match="/">

    <html>

    <body>

    <table border="2" bgcolor="yellow">

    <tr>

    <th>Title</th>

    <th>Artist</th>

    </tr>

    <xsl:for-each select="CATALOG/CD">

    <tr>

    <td><xsl:value-of select="TITLE"/></td>

    <td><xsl:value-of select="ARTIST"/></td>

    </tr>

    </xsl:for-each>

    </table>

    </body>

    </html>

    </xsl:template>

    </xsl:stylesheet>


    下面是在服务器端转换XML文件为HTML文件的原代码:


    <%

    ′Load the XML

    set xml = Server.CreateObject("Microsoft.XMLDOM")

    xml.async = false

    xml.load(Server.MapPath("cd_catalog.xml"))


    ′Load the XSL

    set xsl = Server.CreateObject("Microsoft.XMLDOM")

    xsl.async = false

    xsl.load(Server.MapPath("cd_catalog.xsl"))


    Response.Write(xml.transformNode(xsl))

    %>


    注意:我们这里的例子采用的是ASP文件,用VBScript编写的。如果您不了解ASP或者VBScript,建议阅读有关书籍。(当然,也可以采用其他的语言编写服务器端程序)


    第一段代码建立一个Microsoft Parser(XMLDOM)解析的对象,并将XML文档读入内存;第二段代码建立另外一个对象并导入XSL文档;最后一行代码将XML文档用XSL文档转换,并将结果输出到HTML文件中。

    ----------------------------------------------
    什么时候毛毛虫可以变蝴蝶?!

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/8/19 21:54:00
     
     zxsaso 美女呀,离线,快来找我吧!
      
      
      等级:大二(研究汇编)
      文章:37
      积分:223
      门派:XML.ORG.CN
      注册:2006/7/18

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给zxsaso发送一个短消息 把zxsaso加入好友 查看zxsaso的个人资料 搜索zxsaso在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 引用回复这个贴子 回复这个贴子 查看zxsaso的博客7
    发贴心情 
    XSL简明教程(2)XSL转换[转帖]

    二.XSL的转换


    1.将XML转换成HTML

    XSL是如何将XML文档转换成HTML文件的呢?我们来看一个例子,下面是XML文档的一部分:


    <xml version="1.0" encoding="ISO8859-1" >

    <CATALOG>

    <CD>

    <TITLE>Empire Burlesque</TITLE>

    <ARTIST>Bob Dylan</ARTIST>

    <COUNTRY>USA</COUNTRY>

    <COMPANY>Columbia</COMPANY>

    <PRICE>10.90</PRICE>

    <YEAR>1985</YEAR>

    </CD>

    ...


    然后我们将下面的XSL文件作为HTML的模板将XML数据转换为HTML文件:


    <xml version=′1.0′>

    <xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/WD-xsl">

    <xsl:template match="/">

    <html>

    <body>

    <table border="2" bgcolor="yellow">

    <tr>

    <th>Title</th>

    <th>Artist</th>

    </tr>

    <xsl:for-each select="CATALOG/CD">

    <tr>

    <td><xsl:value-of select="TITLE"/></td>

    <td><xsl:value-of select="ARTIST"/></td>

    </tr>

    </xsl:for-each>

    </table>

    </body>

    </html>

    </xsl:template>

    </xsl:stylesheet>


    在上面的代码中, xsl:for-each元素的作用是定位XML文档中的哪些元素需要按以下模板显示。select属性用来定义源文件中的元素名。指定属性的这种语法又称为XML
    Pattern(模式),类似文件子目录的表示形式。xsl:value-of元素用来在当前层次中插入子元素的内容模板。

    因为XSL样式表自身也是一个XML文档,因此,XSL文件的开头以一个XML声明开始。 xsl:stylesheet元素用来声明这是一个样式表文件。<xsl:template
    match="/">语句表示XML的源文档在当前目录下。

    如果为XML文档加上XSL样式表,看下面代码第2行,你的浏览器就可以精确的将XML 文档转换为HTML文件。


    <xml version="1.0" encoding="ISO8859-1" >

    <xml-stylesheet type="text/xsl" href="cd_catalog.xsl">

    <CATALOG>

    <CD>

    <TITLE>Empire Burlesque</TITLE>

    <ARTIST>Bob Dylan</ARTIST>

    <COUNTRY>USA</COUNTRY>

    <COMPANY>Columbia</COMPANY>

    <PRICE>10.90</PRICE>

    <YEAR>1985</YEAR>

    </CD>

    ----------------------------------------------
    什么时候毛毛虫可以变蝴蝶?!

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/8/19 22:17:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/5/12 10:19:16

    本主题贴数7,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    93.750ms