xsl入門
上期我們講到用css(層疊樣式表)來格式化xml文件,其效果並不很令人滿意。實際上css用來格式化html標記比較合適些,只是因為它簡單才在上例中採用。
xml在更多的時候只是一種資料檔案,怎樣將它變為我們日常所看到的html格式那樣的檔案呢?如果我們將xml檔案比作結構化的原料的話,那麼xsl就好比「篩子「與「模子「,篩子選取自己需要的原料,這些原料再通過模子形成最終的產品:html。
這個模子大致是這樣:我們先設計好表現的頁面,再將其中需要從xml中獲取資料來填充內容的部分「挖掉「,然後用xsl語句從xml中篩出相關的資料來填充。一言以譬之:這xsl實際上就是html的乙個「殼子「,xml資料利用這個「殼「來生成「傳統「的html。
xml在展開時是乙個樹形結構,我們將樹形結構中自定義標記稱為節點,節點之間存在父子、兄弟關係,我們要訪問其中的結點從根結點就要以」/」來層層進入。
在xsl這個殼中,我們要從原料庫??xml裡提取相關的資料,就要用到xsl提供的模式化查詢語言。所謂模式化查詢語言,就是通過相關的模式匹配規則表示式從xml裡提取資料的特定語句,即我們上所說的「篩子「。
選擇模式
測試模式
< xsl:if > 和< xsl:when >
匹配模式
< xsl:template >
我們現在就分別對之進行介紹。
一、 選擇模式
選擇模式語句將資料從xml中提取出來,是一種簡單獲得資料的方法,這幾個標記都有乙個select屬性,選取xml中特定的結點名的資料。
1、< xsl:for-each >
如在xml中有這樣的資料:
< author >
< name >小禹< /name >
< name >春華< /name >
< name >秋實< /name >
< /author >
我們要讀取這三個作者名字,是乙個乙個地按」author/name」方法來讀取嗎,可有多個這樣的name呀?如果有一種程式性的語句來迴圈讀取有多好啊!
想得很對,xsl提供了這樣的具有程式語言性質的語句< xsl:for-each >
用它讀取這三個作者名字的方法如下:
< xsl:for-each select=」author/name」 >
…….< ./xsl:for-each >
select,顧名思義:選取,它可以選定xml中特定唯一的標記,也可以選擇某一類相同的標記,我們稱之為結點集。
語法:
< xsl:for-each select="pattern" order-by="sort-criteria-list">
屬性:
1. select
根據xsl樣式查詢考察上下文以決定哪類結點集(滿足select條件)使用此樣式描述。作為一種簡化的表示就是,如果你想對文件中的某一種標記的內容的顯示方式進行格式化,就可以將讓select等於此元素的標記名。例如欲對標記xml_mark進行格式化,即可用如下方式表示:
< xsl:for-each select="xml_mark" >
< !--樣式定義-- >
< /xsl:for-each >
2. order-by
以分號(;)分隔、作為排序標準的列表。在列表元素前新增加號(+)表示按此標記的內容以公升序排序,新增減號(-)表示逆序排序。作為一種簡化的表示就是,排序標準列表就是由select規定的標記的子標記的序列,每個標記之間以(;)分隔。
2、< xsl:value-of >
< xsl:for-each >模式只是選取節點,並沒有取出節點的值,好比猴子只是爬到了樹的某個枝幹上,那麼就用< xsl:value-of >來摘「勝利果實「吧!
語法:
< xsl:value-of select="pattern" >提取節點的值
屬性:
select用來與當前上下文匹配的xsl式樣。簡單的講,如果要在xsl文件某處插入某個xml標記(假定是xml_mark標記)的內容,可用如下方式表示:
< xsl:value-of select="xml_mark" >< /xsl:value-of >
或 < xsl:value-of select="xml_mark"/ >
示例:此處仍以上期的個人簡歷的作為例子,我們需要對檔案(個人簡歷.xml)作一定修改,確切的說是將其中的第二行
< ?xml:stylesheet type="text/css" href="resume.css"? >
修改為
< ?xml:stylesheet type="text/xsl" href="resume.xsl"? >
然後建立乙個新檔案:resume.xsl,其內容如下:
< title >個人簡歷< /title >
< /head >< body >
< xsl:for-each select="resume" >
< p/ >
< table border="1" cellspacing="0" >
< caption style="font-size: 150%; font-weight: bold" >
個人簡歷
< /caption >
< tr >
< th >姓名< /th >< td >< xsl:value-of select="name"/ >< /td >
< th >性別< /th >< td >< xsl:value-of select="***"/ >< /td >
< th >生日< /th >< td >< xsl:value-of select="birthday"/ >< /td >
< /tr >
< tr >
< th >技能< /th >< td colspan="5" >< xsl:value-of select="skill"/ >< /td >
< /tr >
< /table >
< /xsl:for-each >
< /body >
< /html >
完成這些以後再來讓我們看一下辛勤勞動的成果,怎麼樣?效果不錯吧。更酷還在後頭呢。現在我們對檔案(個人簡歷.xml)作進一步的修改:
1. 在標記< resume >前新增乙個新標記< document >;
2. 將標記對< resume >< /resume >之間的內容(包括這一對標記)複製並貼上在其後,並在最後用< document >結束。
3. 以notepad.exe開啟檔案resume.xsl,在標記< html >之後新增文字:< xsl:for-each select="document" >;在標記< /html >之前新增文字:< /xsl:for-each >,儲存檔案。
4. 在瀏覽器中開啟檔案(個人簡歷.xml)。看到了什麼?兩份個人簡歷!
就這樣,利用xml我們可以編寫內容與樣式完成分離的文件!當然,xsl檔案比一般的html檔案要複雜一些,然而一旦完成則可用於格式化所有同類的xml文件。
注:如果拷貝**,請將空格刪除
跟我學XSL(二)
上期我們講到用css 層疊樣式表 來格式化xml文件,其效果並不很令人滿意。實際上css用來格式化html標記比較合適些,只是因為它簡單才在上例中採用。xml在更多的時候只是一種資料檔案,怎樣將它變為我們日常所看到的html格式那樣的檔案呢?如果我們將xml檔案比作結構化的原料的話,那麼xsl就好比...
跟我學XSL(二)
上期我們講到用css 層疊樣式表 來格式化xml文件,其效果並不很令人滿意。實際上css用來格式化html標記比較合適些,只是因為它簡單才在上例中採用。xml在更多的時候只是一種資料檔案,怎樣將它變為我們日常所看到的html格式那樣的檔案呢?如果我們將xml檔案比作結構化的原料的話,那麼xsl就好比...
跟我學XSL(二)
分享一下我老師大神的人工智慧教程!零基礎,通俗易懂!上期我們講到用css 層疊樣式表 來格式化xml文件,其效果並不很令人滿意。實際上css用來格式化html標記比較合適些,只是因為它簡單才在上例中採用。xml在更多的時候只是一種資料檔案,怎樣將它變為我們日常所看到的html格式那樣的檔案呢?如果我...