我們知道 XML+XSLT就可以直接輸出到支持XML的瀏覽器上,如IE 5.0以上,但是,我們還要考慮到有不少瀏覽器不直接支持XML,在這種情況下,我們需要在服務(wù)器上進(jìn)行轉(zhuǎn)換成html輸出到瀏覽器,這種臨時(shí)過渡辦法恐怕要在一段時(shí)間內(nèi)一直要使用. 使用Jsp 加上tablib標(biāo)識(shí)庫(kù),我們可以完成這種轉(zhuǎn)換。
著名open source項(xiàng)目組jakarta.apache.org推出的系列標(biāo)識(shí)庫(kù)中,就有這個(gè)功能的tanglib:http://jakarta.apache.org/taglibs/doc/xsl-doc/intro.html
按照jakarta配置方法,有點(diǎn)繁瑣,需要修改或定義Web.xml,本人經(jīng)過摸索,使用下列相當(dāng)簡(jiǎn)單的辦法,就可以使Jsp能成功運(yùn)行XSL這個(gè)標(biāo)識(shí)庫(kù)了。
xsl標(biāo)識(shí)庫(kù)有三個(gè)關(guān)鍵包:
xerces.jar 可以在http://xml.apache.org/中得到
xalan.jar 可以在http://xml.apache.org/中得到
xsl.jar 從http://jakarta.apache.org/taglibs/doc/xsl-doc/intro.html得到
1.將這三個(gè)包放置到Tomcat的common/lib目錄下,或者直接放入Classpath環(huán)境中。
2.在JSP中調(diào)用標(biāo)識(shí)庫(kù):
原來Jakarta推薦方法是:
<%@taglib uri="http://jakarta.apache.org/taglibs/xsl-1.0" prefix="xsl" %>
這就需要在/WEB-INF/web.xml下定義一下http://jakarta.apache.org/taglibs/xsl-1.0指向。如:
<taglib>
<taglib-uri>http://jakarta.apache.org/taglibs/xsl-1.0</taglib-uri>
<taglib-location>/WEB-INF/xsl.tld</taglib-location>
</taglib>
這種做法雖然很標(biāo)準(zhǔn),但是,如果你的容器一直使用tomcat,就完全不必了。
我們的做法是:
<%@taglib uri="xsl.jar" prefix="xsl" %>
我們以Jakarta的XSL taglib附帶的Apply.jsp為例,正好了解一下Jsp XML XSLT三者之間的關(guān)系:
Apply.jsp
<%@taglib uri="xsl.jar" prefix="xsl" %>
<html>
<head>
<title>Employee List</title>
</head>
<body bgcolor="white">
<p>下面展示了Jsp的四種組合XML XSLT的方法:
<p>下面使用apply方法,將已經(jīng)存在的employees.xml和employeeList.xsl結(jié)合在一起
<xsl:apply xml="/xml/employees.xml" xsl="/xml/employeeList.xsl"/>
<hr>
<p>下面是使用已經(jīng)存在employeeList.xsl 然后在Jsp中自己直接寫入XML數(shù)據(jù).
<xsl:apply xsl="/xml/employeeList.xsl">
<?xml version="1.0" encoding="ISO-8859-1"?>
<employees>
<employee id="123">
<first-name>John</first-name>
<last-name>Doe</last-name>
<telephone>800-555-1212</telephone>
</employee>
<employee id="456">
<first-name>Jane</first-name>
<last-name>Smith</last-name>
<telephone>888-555-1212</telephone>
</employee>
<employee id="789">
<first-name>George</first-name>
<last-name>Taylor</last-name>
<telephone>555-555-1212</telephone>
</employee>
</employees>
</xsl:apply>
<hr>
<p>下面使使用include調(diào)用的辦法,這樣一個(gè)XSLT樣式可以適應(yīng)不同的XML文件。
<xsl:apply xsl="/xml/employeeList.xsl">
<xsl:include page="/xml/employees.xml"/>
</xsl:apply>
<hr>
<p>下面是使用import方法,在page-scope(類似scope="page")中導(dǎo)入XML文件</p>
<xsl:import id="data" page="/xml/employees.xml"/>
<xsl:apply nameXml="data" xsl="/xml/employeeList.xsl"/>
</body>
在上面程序中,展示了四種Jsp組合XML XSLT的方法,基本可以滿足我們的需要。注意上面的XML文件路徑是"/xml/",這是相對(duì)Tomcat容器的絕對(duì)路徑。
我們簡(jiǎn)單看一下employeeList.xsl和employees.xml內(nèi)容:
employeeList.xsl類似html中的CSS,主要是對(duì)XML中數(shù)據(jù)顯示方式進(jìn)行定義:
<?xml version="1.0"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="employees">
<table border="1" width="100%">
<tr>
<th>ID</th>
<th>Employee Name</th>
<th>Phone Number</th>
</tr>
<xsl:for-each select="employee">
<tr>
<td>
<xsl:value-of select="@id"/>
</td>
<td>
<xsl:value-of select="last-name"/>,
<xsl:value-of select="first-name"/>
</td>
<td>
<xsl:value-of select="telephone"/>
</td>
</tr>
</xsl:for-each>
</table>
</xsl:template>
</xsl:stylesheet>
employees.xml
<?xml version="1.0" encoding="ISO-8859-1"?>
<employees>
?。糴mployee id="123">
<first-name>John</first-name>
?。糽ast-name>Doe</last-name>
?。紅elephone>800-555-1212</telephone>
?。?employee>
?。糴mployee id="456">
?。糵irst-name>Jane</first-name>
<last-name>Smith</last-name>
?。紅elephone>888-555-1212</telephone>
</employee>
<employee id="789">
?。糵irst-name>George</first-name>
?。糽ast-name>Taylor</last-name>
?。紅elephone>555-555-1212</telephone>
?。?employee>
</employees>
如果我們?cè)趀mployees.xml頂部加入:
<?xml:stylesheet type="text/xsl" href="catalog.xsl"?>
用支持XML的IE 5.0以上瀏覽器調(diào)用,其顯示頁(yè)面就和Apply.jsp顯示頁(yè)面是一樣的。
您可能感興趣的文章:- JS實(shí)現(xiàn)讀取xml內(nèi)容并輸出到div中的方法示例
- javascript 讀取XML數(shù)據(jù),在頁(yè)面中展現(xiàn)、編輯、保存的實(shí)現(xiàn)
- JavaScript 解析讀取XML文檔 實(shí)例代碼
- JS讀取XML文件示例代碼
- firefox中JS讀取XML文件
- JS通過ajax動(dòng)態(tài)讀取xml文件內(nèi)容的方法
- JS實(shí)現(xiàn)加載和讀取XML文件的方法詳解
- JS讀取XML文件數(shù)據(jù)并以table形式顯示數(shù)據(jù)的方法(兼容IE與火狐)
- JS使用ajax從xml文件動(dòng)態(tài)獲取數(shù)據(jù)顯示的方法
- javascript XML數(shù)據(jù)顯示為HTML一例
- JavaScript實(shí)現(xiàn)讀取與輸出XML文件數(shù)據(jù)的方法示例