• <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 編程之道 閱讀(262) 評論(0)  編輯 收藏 引用 所屬分類: web編程

            欧美日韩精品久久久久| 色综合久久久久综合体桃花网 | 欧美久久一级内射wwwwww.| 久久久久久综合一区中文字幕| 亚洲午夜精品久久久久久人妖| 久久精品一区二区影院| 四虎国产精品成人免费久久| 色综合久久中文字幕无码| 国产亚洲成人久久| 久久亚洲美女精品国产精品| 国产AV影片久久久久久| 伊人久久精品无码av一区| 狠狠色丁香婷婷综合久久来来去 | 久久福利青草精品资源站免费| 久久久精品国产亚洲成人满18免费网站| 99久久国产亚洲综合精品| 亚洲精品国产成人99久久| 无遮挡粉嫩小泬久久久久久久| 久久AAAA片一区二区| 国产精品久久网| 亚洲熟妇无码另类久久久| 久久久噜噜噜久久中文字幕色伊伊| 国产午夜精品久久久久免费视 | 久久无码精品一区二区三区| 久久96国产精品久久久| 日本欧美久久久久免费播放网| 亚洲国产精品成人AV无码久久综合影院 | 777米奇久久最新地址| 久久这里有精品| 久久只这里是精品66| 久久久久国产一区二区| 久久se这里只有精品| 国内精品久久久久久麻豆| 国产精品熟女福利久久AV| 2021国产成人精品久久| 久久精品国产亚洲沈樵| 亚洲国产精品久久久久婷婷软件| 2022年国产精品久久久久| 狠狠88综合久久久久综合网| 狠狠色丁香婷婷久久综合不卡| 91视频国产91久久久|