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

            日韩精品久久久肉伦网站| 伊人久久综合热线大杳蕉下载| 国产日韩欧美久久| 久久久久九国产精品| 99蜜桃臀久久久欧美精品网站| 日日噜噜夜夜狠狠久久丁香五月 | 久久精品国产亚洲一区二区三区| 色偷偷88欧美精品久久久| 久久天天躁狠狠躁夜夜avapp| 精品人妻伦一二三区久久| 国产激情久久久久久熟女老人| 久久精品国产亚洲沈樵| 思思久久好好热精品国产| 日本精品久久久久中文字幕| 久久精品aⅴ无码中文字字幕不卡| 久久精品视频免费| 久久久久99精品成人片直播| 久久亚洲AV无码精品色午夜| 一级做a爱片久久毛片| 久久久久久夜精品精品免费啦| 亚洲AV伊人久久青青草原| 久久久久久免费一区二区三区| 东方aⅴ免费观看久久av| 亚洲国产香蕉人人爽成AV片久久| 精品一区二区久久| 色8久久人人97超碰香蕉987| 久久亚洲中文字幕精品一区| 久久综合综合久久97色| 久久99精品国产99久久6男男| 久久久av波多野一区二区| 亚洲AV日韩AV天堂久久| 久久久久久久综合狠狠综合| 免费一级做a爰片久久毛片潮| 久久午夜电影网| 国产精品九九久久免费视频| 久久亚洲精品中文字幕三区| 久久免费小视频| 一本大道久久a久久精品综合| 日本精品久久久久中文字幕| 国产成人精品久久亚洲高清不卡 国产成人精品久久亚洲高清不卡 国产成人精品久久亚洲 | 久久福利青草精品资源站免费|