DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> XML學習教程 >> XML詳解 >> 跟我學XSL(3)XSL模板與匹配模式
跟我學XSL(3)XSL模板與匹配模式
編輯:XML詳解     

 經過前幾日的學習,我們學習了XHtml文檔的編寫和以及三個XSL元素,已能編寫相當靈活的XSL文檔,今天將學習的是XSL模板的編寫。我們都知道,短的文檔、程序十分好讀,但當規模增大後,其復雜性也以更快的速度增加。

  前面我們學了<xsl:for-each>、<xsl:value-of>等,可以用它們對XML數據實現簡單的格式化輸出,但如果遇到比較復雜的XML格式輸出,將XSL按照要求依次寫下來的話,一是設計困難,可擴展性差,不利於人員之間的分工協作;另則,可修改性很差,可能會出現牽一發而動全軍的情況,不利於維護。程序中模塊化設計逐步細化的方法在這裡得到了應用!

  XSL模板將XSL的設計細化成一個個模板(塊),最後再將這些模板(塊)組合成一個完整的XSL;好比船與集裝箱,我們不是將所有的貨物一件件地堆起來,而是裝在各自的集裝箱中,然後再在船上將這些集裝箱堆放起來。這種方法可以使你先從整體上考慮整個XSL的設計,然後將一些表現形式細化成不同的模塊,再具體設計這些模塊,最後將它們整合在一起,這樣,將宏觀與微觀結合起來,符合人們條理化、規范化要求。

  裝集裝箱--書寫模板(塊):<xsl:template>

  語法:
<xsl:template match="node-context" language="language-name">

  屬性:

  match ── 確定什麼樣的情況下執行此模板。作為一種簡化的說明,在此處使用標記的名字;其中最上層模板必須將match設為"/"。

  language ── 確定在此模板中執行什麼腳本語言,其取值與Html中的SCRIPT標記的LANGUAGE屬性的取值相同,缺省值是JScript。

  <xsl:template>用match屬性從XML選取滿足條件的節點,征對這些特定的節點形成一個特定輸出形式的模板。

吊集裝箱上船--調用模板(塊):<xsl:apply-templates>

  語法:

  <xsl:apply-templates select="pattern" order-by="sort-criteria-list">

  屬性:

  select ── 確定在此上下文環境中應執行什麼模板,即選取用< xsl:template >標記建立的模板(塊)。

  order-by ── 以分號(;)分隔的排序標准,通常是子標記的序列。

  示例:

  以個人簡歷為例,為便於處理我們希望"技能"中每一項都用標記對<skill></skill>括起來,有多少項技能就有多少個這種標記對,經過修改後的個人簡歷XML文檔內容如下:

  <?XML version="1.0" encoding="GB2312"?>
<?XML-stylesheet type="text/xsl" href="resume_template.xsl"?>
<document>
<resume>
<name>禹希初</name>
<sex>男</sex>
<birthday>1977.5</birthday>
<skill>數據庫設計與維護</skill>
<skill>web開發</skill>
</resume>
</document>
  然後,建立一個新XSL文件resume_template.xsl,采用模板的形式,其內容如下:
<?XML version="1.0" encoding="GB2312"?>
<xsl:stylesheet XMLns:xsl="http://www.w3.org/TR/WD-xsl">
<!--根模板-->
<xsl:template match="/">
<Html><HEAD><TITLE>個人簡歷</TITLE></HEAD>
<BODY>
<xsl:apply-templates select="document/resume"/>
</BODY>
</Html>
</xsl:template>
<!--簡歷模板-->
<xsl:template match="resume">
<TABLE border="1" cellspacing="0">
<CAPTION>個人簡歷(
<xsl:eval>formatIndex(childNumber(this),"I")</xsl:eval>
)</CAPTION>
<xsl:apply-templates select="name"/>
<xsl:apply-templates select="sex"/>
<xsl:apply-templates select="birthday"/>
<TR/>
<TD>技能</TD><TD COLSPAN="5">
<TABLE cellspacing="0">
<xsl:apply-templates select="skill"/>
</TABLE>
</TD>
</TABLE>
<BR/>
</xsl:template>
<!--姓名模板-->
<xsl:template match="name"><TD>姓名</TD>
<TD><xsl:value-of/></TD>
</xsl:template>
<!--性別模板-->
<xsl:template match="sex"><TD>性別</TD>
<TD><xsl:value-of/></TD>
</xsl:template>
<!--生日模板-->
<xsl:template match="birthday"><TD>生日</TD>
<TD><xsl:value-of/></TD>
</xsl:template>
<!--技能模板-->
<xsl:template match="skill">
<TR><TD><xsl:value-of/></TD></TR>
</xsl:template>
</xsl:stylesheet>


上例在浏覽器中的樣子(IE5.0或更新版本)
  保存文件,打開文件(個人簡歷.XML),效果令人滿意吧。其實要做到同樣的效果,用前面三周介紹的方法也可做,但你得把它作為一整體考慮。
  在上面的XSL文件中,我們將性別、生日、技能等數據項分別用模板來單獨寫,再用<xsl:apply-template>來調用,這樣,即使你日後要對這些模板作相應的修改與擴充也很方便,不致於出現互相干擾、混雜不清的情況。這種從上至下、逐層細化的設計方法,極大地減少工作復雜程度,也大大減少了差錯的產生,可以實現多人的協作設計。

  注意:如果XML文檔中不同標記有同名的子標記,在為其編寫模板時,應把父標記作為其前綴,格式為(parent_mark/child_mark)。模板文件必須有一個根模板,其屬性match是"/"。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved