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

    >> 本版讨论XSL,XSLT,XSL-FO,CSS等技术
    [返回] 中文XML论坛 - 专业的XML技术讨论区XML.ORG.CN讨论区 - XML技术『 XSL/XSLT/XSL-FO/CSS 』 → 两种实现数据岛的方法 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 1808 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: 两种实现数据岛的方法 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     anchen0617 帅哥哟,离线,有人找我吗?双子座1983-6-17
      
      
      威望:5
      等级:大二(研究C++)
      文章:281
      积分:3413
      门派:XML.ORG.CN
      注册:2004/10/17

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给anchen0617发送一个短消息 把anchen0617加入好友 查看anchen0617的个人资料 搜索anchen0617在『 XSL/XSLT/XSL-FO/CSS 』的所有贴子 访问anchen0617的主页 引用回复这个贴子 回复这个贴子 查看anchen0617的博客楼主
    发贴心情 两种实现数据岛的方法

    1、为<xsl:param>标签设定参数实现动态排序(推荐)
    <html>
    <body>
    <table DATASRC="#catalogs" border=1>
    <thead>
    <tr>
    <td onclick="sort('TITLE','descending');">TITLE</td>
    <td>ARTIST</td>
    <td onclick="sort('COUNTRY','ascending');">COUNTRY</td>
    <td>COMPANY</td>
    <td>PRICE</td>
    <td>YEAR</td>
    </tr>
    </thead>
    <tbody>
    <tr>
    <td ><div DATAFLD="TITLE"></div></td>
    <td ><div DATAFLD="ARTIST"></div></td>
    <td ><div DATAFLD="COUNTRY"></div></td>
    <td ><div DATAFLD="COMPANY"></div></td>
    <td ><div DATAFLD="PRICE"></div></td>
    <td ><div DATAFLD="YEAR"></div></td>
    </tr>
    </tbody>
    </table>
    <xml id="catalogs">
    <CATALOG>
    <CD>
    <TITLE>Empire Burlesque</TITLE>
    Bob Dylan
    <COUNTRY>USA</COUNTRY>
    <COMPANY>Columbia</COMPANY>
    <PRICE>10.90</PRICE>
    <YEAR>1985</YEAR>
    </CD>
    <CD>
    <TITLE>Burlesque</TITLE>
    Dylan
    <COUNTRY>UA</COUNTRY>
    <COMPANY>umbia</COMPANY>
    <PRICE>1.90</PRICE>
    <YEAR>1987</YEAR>
    </CD>
    <CD>
    <TITLE>Empire</TITLE>
    Bob
    <COUNTRY>US</COUNTRY>
    <COMPANY>bia</COMPANY>
    <PRICE>12.90</PRICE>
    <YEAR>1995</YEAR>
    </CD>
    </CATALOG>
    </xml>

    <xml id="xstyle">
    <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
    <xsl:output method="xml"/>
    <xsl:param name="sortorder" select="'descending'"/>
    <xsl:param name="sortfield" select="'xxx'"/>
    <xsl:template match="/">
    <CATALOG>
    <xsl:for-each select="CATALOG/CD">
    <xsl:sort select="*[name()=$sortfield]" order="{$sortorder}" />
    <CD>
    <TITLE><xsl:value-of select="TITLE"/></TITLE>
    <xsl:value-of select="ARTIST"/>
    <COUNTRY><xsl:value-of select="COUNTRY"/></COUNTRY>
    <COMPANY><xsl:value-of select="COMPANY"/></COMPANY>
    <PRICE><xsl:value-of select="PRICE"/></PRICE>
    <YEAR><xsl:value-of select="YEAR"/></YEAR>
    </CD>
    </xsl:for-each>
    </CATALOG>
    </xsl:template>
    </xsl:stylesheet>
    </xml>

    <script language="vbscript">
    function sort(strSortField, strSortOrder)

    dim objXSL, objXML, objTemplate, objProcessor, strHTML, strDrinkType

    Set objXML = CreateObject("Msxml2.FreeThreadedDOMDocument")
    Set objXSL = CreateObject("Msxml2.FreeThreadedDOMDocument")

    'Load the XML document
    objXML.async = False
    objXML.Loadxml catalogs.xml

    'Load the XSL document
    objXSL.async = False
    objXSL.Loadxml xstyle.xml

    'Create an instance of our XSL Template object
    Set objTemplate = CreateObject("MSXML2.XSLTemplate")

    'Create an instance of our stylesheet object using our recently loaded XSLT document
    Set objTemplate.stylesheet = objXSL

    'Create an instance of our Processor object
    Set objProcessor = objTemplate.createProcessor

    'Define the input object for our object equal to our recently loaded XML document
    objProcessor.input = objXML

    'Now, finally we can add any parameters that we require to our Template processor
    objProcessor.AddParameter "sortfield", strSortField
    objProcessor.AddParameter "sortorder", strSortOrder

    'Last but not least we do our transformation
    objProcessor.Transform

    'Store the results of the output into a string.
    strXML = objProcessor.output

    'Load up an XML DOM object from the recent XML output
    objXML.loadxml strXML

    'Select only the "employees" elements from our document object
    objXML.selectNodes("//CATALOG")

    'Load our Data Island using our new XML object
    catalogs.loadxml objXML.xml
    end function
    </script>

    <script language="javascript">
    function sort2(xmlObj, xslObj, sortByColName)
    {
    var xmlData=eval("document.all."+xmlObj).XMLDocument;
    var xslData=eval("document.all."+xslObj).XMLDocument;
    var nodes=xslData.documentElement.selectSingleNode("xsl:for-each");
    nodes.selectSingleNode("@order-by").value=sortByColName;

    xmlData.documentElement.transformNodeToObject(xslData.documentElement,xmlData);
    }
    </script>

    </body>
    </html>

    2、直接通过DOM实现,灵活性欠缺:
    <html>
    <body>
    <table DATASRC="#catalogs" border=1>
    <thead>
    <tr>
    <td onclick="sort('catalogs','xstyle','TITLE');">TITLE</td>
    <td>ARTIST</td>
    <td>COUNTRY</td>
    <td>COMPANY</td>
    <td>PRICE</td>
    <td>YEAR</td>
    </tr>
    </thead>
    <tbody>
    <tr>
    <td ><div DATAFLD="TITLE"></div></td>
    <td ><div DATAFLD="ARTIST"></div></td>
    <td ><div DATAFLD="COUNTRY"></div></td>
    <td ><div DATAFLD="COMPANY"></div></td>
    <td ><div DATAFLD="PRICE"></div></td>
    <td ><div DATAFLD="YEAR"></div></td>
    </tr>
    </tbody>
    </table>

    <xml id='catalogs'>
    <CATALOG>
    <CD>
    <TITLE>Empire Burlesque</TITLE>
    Bob Dylan
    <COUNTRY>USA</COUNTRY>
    <COMPANY>Columbia</COMPANY>
    <PRICE>10.90</PRICE>
    <YEAR>1985</YEAR>
    </CD>
    <CD>
    <TITLE>Burlesque</TITLE>
    Dylan
    <COUNTRY>UA</COUNTRY>
    <COMPANY>umbia</COMPANY>
    <PRICE>1.90</PRICE>
    <YEAR>1987</YEAR>
    </CD>
    <CD>
    <TITLE>Empire</TITLE>
    Bob
    <COUNTRY>US</COUNTRY>
    <COMPANY>bia</COMPANY>
    <PRICE>12.90</PRICE>
    <YEAR>1995</YEAR>
    </CD>
    </CATALOG>
    </xml>

    <xml id="xstyle">
    <CATALOG>
    <xsl:for-each select="CD" order-by="+TITLE" xmlns:xsl="http://www.w3.org/TR/WD-xsl">
    <CD>
    <TITLE><xsl:value-of select="TITLE"/></TITLE>
    <xsl:value-of select="ARTIST"/>
    <COUNTRY><xsl:value-of select="COUNTRY"/></COUNTRY>
    <COMPANY><xsl:value-of select="COMPANY"/></COMPANY>
    <PRICE><xsl:value-of select="PRICE"/></PRICE>
    <YEAR><xsl:value-of select="YEAR"/></YEAR>
    </CD>
    </xsl:for-each>
    </CATALOG>
    </xml>

    <script language="javascript">
    function sort(xmlObj, xslObj, sortByColName)
    {
    var xmlData=eval("document.all."+xmlObj).XMLDocument;
    var xslData=eval("document.all."+xslObj).XMLDocument;
    var nodes=xslData.documentElement.selectSingleNode("xsl:for-each");
    nodes.selectSingleNode("@order-by").value=sortByColName;

    xmlData.documentElement.transformNodeToObject(xslData.documentElement,xmlData);
    }
    </script>
    </body>
    </html>


       收藏   分享  
    顶(0)
      




    ----------------------------------------------
    xml这门语言太好了,我们共同努力吧!!!!!

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

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

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