青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 47, 文章 - 10, 評論 - 8, 引用 - 0
數據加載中……

跟我學XSL(二)——XSL入門

 上期我們講到用CSS(層疊樣式表)來格式化XML文檔,其效果并不很令人滿意。實際上CSS用來格式化HTML標記比較合適些,只是因為它簡單才在上例中采用。

  XML在更多的時候只是一種數據文件,怎樣將它變為我們日常所看到的HTML格式那樣的文件呢?如果我們將XML文件比作結構化的原料的話,那么XSL就好像"篩子"與"模子",篩子選取自己需要的原料,這些原料再通過模子形成最終的產品:HTML。

  這個模子大致是這樣:我們先設計好表現的頁面,再將其中需要從XML中獲取數據來填充內容的部分"挖掉",然后用XSL語句從XML中篩出相關的數據來填充。一言以譬之:這XSL實際上就是HTML的一個"殼子",XML數據利用這個"殼"來生成"傳統"的HTML。

  XML在展開時是一個樹形結構,我們將樹形結構中自定義標記稱為節點,節點之間存在父子、兄弟關系,我們要訪問其中的結點從根結點就要以"/"來層層進入。

  在XSL這個殼中,我們要從原料庫XML里提取相關的數據,就要用到XSL提供的模式化查詢語言。所謂模式化查詢語言,就是通過相關的模式匹配規則表達式從XML里提取數據的特定語句,即我們上面所說的"篩子"。

  參考微軟的"XSL開發者指南",我們大致可將模式語言分為三種:

  選擇模式:

<xsl:for-each>、<xsl:value-of>和 <xsl:apply-templates>

  測試模式:

<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,其內容如下:
<?xml?version="1.0"?encoding="GB2312"?>
<HTML?xmlns:xsl="http://www.w3.org/TR/WD-xsl">
<HEAD>
<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="sex"/></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>
o_xsl_4.JPG
  完成這些以后再來讓我們看一下辛勤勞動的成果,怎么樣?效果不錯吧。更酷還在后頭呢。現在我們對文件(個人簡歷.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)??吹搅耸裁矗績煞輦€人簡歷!
o_xsl_5.JPG
  就這樣,利用XML我們可以編寫內容與樣式完成分離的文檔!當然,XSL文件比一般的HTML文件要復雜一些,然而一旦完成則可用于格式化所有同類的XML文檔。

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

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲国产精品福利| 欧美人与性动交a欧美精品| 欧美成人高清| 欧美国产1区2区| 老司机免费视频久久| 欧美α欧美αv大片| 欧美高清视频www夜色资源网| 欧美成ee人免费视频| 最新中文字幕亚洲| 日韩一级在线| 欧美亚洲综合网| 蜜桃av噜噜一区| 欧美吻胸吃奶大尺度电影| 国产精品久久看| 精品999久久久| 亚洲性av在线| 欧美波霸影院| 亚洲免费影视第一页| 噜噜噜噜噜久久久久久91| 欧美黑人国产人伦爽爽爽| 国产精品国产精品| 在线免费不卡视频| 亚洲一区影音先锋| 欧美高清视频| 亚洲伊人伊色伊影伊综合网| 免费黄网站欧美| 国产区精品在线观看| 亚洲人成毛片在线播放| 久久大综合网| 亚洲三级视频在线观看| 久久成人免费| 国产精品久久久久7777婷婷| 亚洲国产天堂久久综合网| 欧美一区二区成人| 一区二区冒白浆视频| 欧美激情久久久久| 国产在线播放一区二区三区| 一本色道久久综合亚洲精品高清| 久久免费视频在线观看| 亚洲一区二区伦理| 欧美日韩中国免费专区在线看| 亚洲国产日韩一区| 久热精品视频| 先锋影音网一区二区| 欧美午夜一区| 一区二区三区日韩精品| 亚洲国产三级| 欧美aaa级| 在线看一区二区| 国产精品美女主播在线观看纯欲| 亚洲激情欧美| 欧美+日本+国产+在线a∨观看| 亚洲欧美视频在线观看| 国产精品你懂的| 亚洲欧美国产一区二区三区| 亚洲毛片视频| 欧美日韩在线视频一区| 一区二区国产日产| 亚洲三级电影全部在线观看高清| 麻豆精品在线播放| 亚洲国产裸拍裸体视频在线观看乱了中文 | 欧美成人国产va精品日本一级| 狠狠色狠狠色综合日日小说| 久久精品二区三区| 欧美在线观看网站| 在线日韩欧美视频| 欧美高清视频在线观看| 欧美国产日韩精品| 一区二区三区久久| 亚洲作爱视频| 国产精品午夜电影| 久久精品天堂| 美国成人直播| 在线亚洲精品| 午夜精品福利一区二区三区av| 国产精品免费视频xxxx | 欧美国产激情二区三区| 欧美第十八页| 亚洲欧美国产77777| 欧美亚洲一区二区三区| 亚洲国内精品在线| 一区二区日韩| 国产日韩一区二区三区在线| 快射av在线播放一区| 欧美成人免费播放| 亚洲欧美日韩国产综合| 午夜视频久久久| 亚洲国产精品va在线看黑人| 日韩一区二区免费高清| 国产三级欧美三级日产三级99| 欧美11—12娇小xxxx| 欧美三级在线播放| 免费成人在线视频网站| 欧美偷拍另类| 欧美福利电影网| 国产精品一区二区三区久久| 欧美成人中文| 国产麻豆午夜三级精品| 亚洲国产欧美久久| 国产自产2019最新不卡| 日韩亚洲欧美成人| 在线看无码的免费网站| 亚洲午夜免费福利视频| 亚洲高清免费视频| 亚洲综合精品一区二区| 亚洲人成毛片在线播放女女| 亚洲欧美中文日韩v在线观看| 91久久视频| 老司机午夜免费精品视频| 欧美精品一区二区在线播放| 久久久久久久一区| 国产精品国产三级国产| 亚洲国产mv| 国内外成人免费激情在线视频网站 | 国产精品大片| 亚洲国产毛片完整版 | 欧美精品v日韩精品v国产精品 | 亚洲视频在线观看网站| 浪潮色综合久久天堂| 午夜精品区一区二区三| 免费日韩视频| 免费成人黄色片| 国产在线欧美日韩| 欧美一级淫片播放口| 新片速递亚洲合集欧美合集| 欧美精品一区二区三区高清aⅴ| 久久综合电影一区| 国产婷婷色一区二区三区四区| 夜夜爽av福利精品导航| 日韩视频精品| 欧美大片国产精品| 欧美高清一区二区| 伊人夜夜躁av伊人久久| 久久精品一级爱片| 久久综合激情| 国产真实乱偷精品视频免| 亚洲一区二区免费视频| 中日韩午夜理伦电影免费| 欧美成ee人免费视频| 久久国内精品自在自线400部| 国产精品久久久久久久午夜| 一卡二卡3卡四卡高清精品视频| 夜久久久久久| 欧美日本国产| 一区二区三区www| 亚洲综合清纯丝袜自拍| 国产精品久久77777| 亚洲一区二区精品在线观看| 欧美一站二站| 狠狠色狠狠色综合日日小说| 久久精品视频在线看| 狂野欧美激情性xxxx| 亚洲福利视频网站| 欧美高清成人| 一区二区三区产品免费精品久久75 | 国产精品美女xx| 欧美亚洲专区| 欧美高清视频www夜色资源网| 亚洲精品在线视频| 欧美午夜一区二区福利视频| 欧美一区深夜视频| 欧美国内亚洲| 亚洲在线一区二区| 黑人巨大精品欧美一区二区小视频 | 欧美日韩成人免费| 亚洲特黄一级片| 久久综合电影| 亚洲视屏在线播放| 国产亚洲一区二区三区在线观看| 久久人人爽人人爽爽久久| 欧美国产日本| 亚洲欧美综合网| 在线免费观看一区二区三区| 欧美日韩国产黄| 久久精品视频在线| 一区二区三区日韩精品视频| 久久久久久久高潮| 在线视频精品一| 激情国产一区二区| 国产精品xvideos88| 久久亚洲精品视频| 亚洲小说欧美另类社区| 欧美韩日高清| 久久精品国产96久久久香蕉| 日韩一级精品| 在线观看精品视频| 国产婷婷精品| 国产精品国产三级国产a| 美国成人毛片| 久久精品电影| 亚洲综合日本| av成人免费| 亚洲人成毛片在线播放| 乱中年女人伦av一区二区| 午夜精品久久久久久久蜜桃app| 日韩一级片网址| 亚洲区一区二| 亚洲激情自拍| 亚洲国产精品成人久久综合一区| 国产日产欧美一区|