• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 47, 文章 - 10, 評論 - 8, 引用 - 0
            數據加載中……

            跟我學XSL(八)——腳本與XSL的結合及應用

             有時,我們可能會希望XML文檔輸出時能對其中內容加上一些統計信息或者如編號什么的,利用前面的知識就不太容易實現了。今天將介紹兩個新元素<xsl:eval>與<xsl:script>,使我們能輕松處理這個難題。

            <xsl:eval>

              含義:計算腳本表達式,輸出一個文本字符串。

              語法:

            <xsl:eval?language="language-name">

              屬性:

              language ── 規定所用腳本語言的名字,可用的屬性有"JavaScript"、"JScript"、"VBScript"、"VBS"等,缺省為"JScript"。

            <xsl:script>

              含義:聲明全局變量或定義函數。

              語法:

            <xsl:script?language="language-name">

              屬性:同<xsl:eval>


              示例:

              不知大家對于第四期《跟我學XML》中的例子是否還有印象?其中的XML文檔并沒有對簡歷編號,但輸出中卻加上了大寫的羅馬數字序號。今天將再舉一稍為復雜一些的例子:

              假如我們編寫一份年終生產統計表,其中需要小計一項,常規的作法是事先將其算出來,現在不必了,我們可以只給出單項統計,顯示時再統計小計一項。請找出《跟我學XML》的第四期,XML文件不必修改,對XSL文件的修改如下:

            <?xml?version="1.0"?encoding="GB2312"?>
            <xsl:stylesheet?xmlns:xsl="http://www.w3.org/TR/WD-xsl">

            <xsl:template?match="/">
            <HTML><HEAD><TITLE>1999年生產統計</TITLE></HEAD>?
            <BODY><xsl:apply-templates?select="document"/></BODY>
            </HTML>
            </xsl:template>

            <xsl:template?match="document">
            <H3>1999年生產統計</H3>?
            <TABLE?border="1"?cellspacing="0">?
            <TH>班組</TH>
            <TH>一季度</TH>
            <TH>二季度</TH>
            <TH>三季度</TH>
            <TH>四季度</TH>
            <xsl:apply-templates?select="report"/>

            <TR><TD>小計</TD>
            <TD><xsl:eval>total(this,"q1")</xsl:eval></TD>
            <TD><xsl:eval>total(this,"q2")</xsl:eval></TD>
            <TD><xsl:eval>total(this,"q3")</xsl:eval></TD>
            <TD><xsl:eval>total(this,"q4")</xsl:eval></TD>
            </TR>

            </TABLE>

            <xsl:script>
            function?total(node,q)
            {
              temp=0;?
              mark='/document/report/'+q;
              v=node.selectNodes(mark);
              for(t=v.nextNode();t;t=v.nextNode())
              {
                temp+=Number(t.text);
              }
              return?temp;?//小計值
            }
            </xsl:script>

            </xsl:template>

            <xsl:template?match="report">
            <TR>
            <TD><xsl:value-of?select="class"/></TD>
            <TD><xsl:apply-templates?select="q1"/></TD>
            <TD><xsl:apply-templates?select="q2"/></TD>
            <TD><xsl:apply-templates?select="q3"/></TD>
            <TD><xsl:apply-templates?select="q4"/></TD>
            </TR>
            </xsl:template>

            <xsl:template?match="q1|q2|q3|q4">
            <!--此處測試產量,如小于等于20則添加一STYLE屬性color,其值為red(紅色)-->?
            <xsl:if?test=".[value()?$le$?20]">?
            <xsl:attribute?name="style">color:red</xsl:attribute>
            </xsl:if>
            <xsl:value-of/>
            </xsl:template>

            </xsl:stylesheet>
            r_xsl_13.JPG

              說明:

              注意到執行結果的變化了嗎?黑體部分為添加部分,注意添加部分分為兩部分,<xsl:script></xsl:script>必須置于</TABLE>之后,切記。

              selectNodes() ── 是XMLDOMObject的一個方法,返回文檔中所有滿足條件的結點的集合,條件與< xsl:for-each >和select屬性的取值采用同樣的寫法,可以加篩選、下標等限制,如尋找一季度產量大于等于50的班組:

            /document/report/q1[value() $ge$ 50]

              以上寫法還有一個更簡單的寫法:

            //q1[value()$ge$50]

              //表示從根結點出發遍歷所有結點,尋找滿足條件的結點,如果文檔內有同名但意義不同的結點則不能用此種方法,非不得已不建議使用。以此為例,如果希望統計年總產量,則可以下述字符串尋找結點(建議使用最后一種,此種描述將精確找到需要匯總的數據):

            //*[value()$gt$0] 或 //(q1|q2|q3|q4) 或 /document/report/(q1|q2|q3|q4)

              nextNode() ── 返回結點集中的下一個結點

              Number() ── 將提供的參數轉換為數值


              下期介紹XSL函數2,用于<xsl:script>及<xsl:eval>中,以及<xsl:if>和<xsl:when>的expr屬性。建議讀者熟悉JavaScript、JScript、VBScript中至少一種,否你能用XSL完成的工作將十分有限。由于篇幅關系,此處不作詳細介紹。

            posted on 2006-09-14 11:17 編程之道 閱讀(279) 評論(0)  編輯 收藏 引用 所屬分類: web編程

            久久国产免费| 国产精品久久久久久福利69堂| 99久久国产免费福利| 亚洲精品乱码久久久久久不卡| 精品伊人久久大线蕉色首页| 精品久久久久久国产| 久久99精品久久久久久久久久| 久久这里只精品99re66| 久久96国产精品久久久| 久久人人爽人人爽人人av东京热| 国产精品久久久久国产A级| 久久久久亚洲AV无码专区桃色| 99久久精品国产一区二区蜜芽| 性色欲网站人妻丰满中文久久不卡| 免费精品久久久久久中文字幕| 波多野结衣中文字幕久久 | 三级韩国一区久久二区综合| 久久伊人精品青青草原高清| 欧洲精品久久久av无码电影| 精品国产青草久久久久福利| 国产亚洲精午夜久久久久久 | 午夜不卡888久久| 97精品依人久久久大香线蕉97 | 久久精品国产亚洲一区二区| 久久婷婷五月综合色高清| 亚洲国产小视频精品久久久三级 | 新狼窝色AV性久久久久久| 香蕉久久夜色精品国产2020| 久久免费99精品国产自在现线 | 99久久精品午夜一区二区| 久久男人Av资源网站无码软件| 久久精品国产精品亚洲毛片| 午夜欧美精品久久久久久久| 伊人久久大香线蕉精品不卡| 国产成人综合久久精品红| 久久国产精品无码一区二区三区 | 香港aa三级久久三级| 狠狠色丁香婷婷综合久久来来去| 99久久99久久精品国产片| 精品国产乱码久久久久久浪潮| 久久国产V一级毛多内射|