亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > XML > 正文

如何靈活調用xsl來解析xml文檔(js異步)

2024-09-05 20:54:33
字體:
來源:轉載
供稿:網友

1.新建一個vs2003的web工程,取名為XMLTest

2.將工程目錄下的WebForm1.aspx中內容全部刪除,只留下頂部的一條語句:

<%@ Page language="c#" Codebehind="WebForm1.aspx.cs" AutoEventWireup="false" Inherits="XMLTest.WebForm1" %>


3.修改WebForm1.aspx.cs中內容,在Page_Load中加入:

以下是引用片段:
XmlDocument doc=new XmlDocument();
String xmlfile=string.Empty;
xmlfile=Context.Request.PhysicalApplicationPath (Request.QueryString["sel"].ToString()=="xml"?"//hello.xml":"//hello.xsl");
doc.Load(xmlfile);
Response.Write(doc.InnerXml);


4.在工程根目錄下新增test.htm,并設為工程首頁:

以下是引用片段:
<html>
<head>
<title></title>
</head>
<body>
<div id="resTree"></div>
<FONT face="宋體"></FONT><input type="button" value="http://www.49028c.com/執行" onclick="GetXml()"><BR>
<script language="JScript">
var srcTree,xsltTree,xt;
var http_request = false;

function GetXml()
{
srcTree = new ActiveXObject("Msxml2.FreeThreadedDOMDocument");
srcTree.async=false;
xsltTree= new ActiveXObject("Msxml2.FreeThreadedDOMDocument");
xsltTree.async = false;
xt=new ActiveXObject("MSXML2.XSLTemplate");
resTree.innerHTML="";
makeRequest("WebForm1.aspx?sel=xml",GetXml_CB);
}

function makeRequest(url,callback) {
http_request = false;
if (window.XMLHttpRequest) { // Mozilla, Safari,...
http_request = new XMLHttpRequest();
if (http_request.overrideMimeType) {
http_request.overrideMimeType('text/xml');
}
} else if (window.ActiveXObject) { // IE
try {
http_request = new ActiveXObject("Msxml2.XMLHTTP");
} catch (e) {
try {
http_request = new ActiveXObject("Microsoft.XMLHTTP");
} catch (e) {}
}
}

if (!http_request) {
alert('Giving up :( Cannot create an XMLHTTP instance');
return false;
}
http_request.onreadystatechange = callback;
http_request.open('GET', url, true);
http_request.send(null);
}

function GetXml_CB() {

if (http_request.readyState == 4) {
if (http_request.status == 200) {
srcTree.loadXML(http_request.responseText);
makeRequest("WebForm1.aspx?sel=xsl",GetXsl_CB);
} else {
alert('There was a problem with the request.');
}
}

}

function GetXsl_CB(){
if (http_request.readyState == 4) {
if (http_request.status == 200) {
xsltTree.loadXML(http_request.responseText);
xt.stylesheet=xsltTree;
var proc=xt.createProcessor();
proc.input=srcTree;
proc.transform();
resTree.innerHTML=proc.output;
} else {
alert('There was a problem with the request.');
}
}

}

function makeRequest(url,callback) {
http_request = false;
if (window.XMLHttpRequest) { // Mozilla, Safari,...
http_request = new XMLHttpRequest();
if (http_request.overrideMimeType) {
http_request.overrideMimeType('text/xml');
}
} else if (window.ActiveXObject) { // IE
try {
http_request = new ActiveXObject("Msxml2.XMLHTTP");
} catch (e) {
try {
http_request = new ActiveXObject("Microsoft.XMLHTTP");
} catch (e) {}
}
}

if (!http_request) {
alert('Giving up :( Cannot create an XMLHTTP instance');
return false;
}
http_request.onreadystatechange = callback;
http_request.open('GET', url, true);
http_request.send(null);
}

</script>

</body>
</html>


5.運行工程,看看效果吧!

hello.xml(注意:我的xml文檔中并沒有指定對應的xsl解析文件名)

以下是引用片段:
<?xml version='1.0'?>

<breakfast-menu>
<food>
<name>Belgian Waffles</name>
<price>$5.95</price>
<description>Two of our famous Belgian Waffles
with plenty of real maple syrup.</description>
<calories>650</calories>
</food>
<food>
<name>Strawberry Belgian Waffles</name>
<price>$7.95</price>
<description>Light Belgian waffles covered with
strawberries and whipped cream.</description>
<calories>900</calories>
</food>
<food>
<name>Berry-Berry Belgian Waffles</name>
<price>$8.95</price>
<description>Light Belgian waffles covered
with an assortment of fresh berries
and whipped cream.</description>
<calories>900</calories>
</food>
<food>
<name>French Toast</name>
<price>$4.50</price>
<description>Thick slices made from our homemade
sourdough bread.</description>
<calories>600</calories>
</food>
<food>
<name>Homestyle Breakfast</name>
<price>$6.95</price>
<description>Two eggs, bacon or sausage, toast,
and our ever-popular hash browns.</description>
<calories>950</calories>
</food>
</breakfast-menu>

hello.xsl

以下是引用片段:
<?xml version="1.0"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="/breakfast-menu">

<xsl:for-each select="food">
<DIV STYLE="background-color:teal; color:white; padding:4px">
<SPAN STYLE="font-weight:bold; color:white"><xsl:value-of select="name"/></SPAN>
至 <xsl:value-of select="price"/>
</DIV>
<DIV STYLE="margin-left:20px; margin-bottom:1em; font-size:10pt">
<xsl:value-of select="description"/>
<SPAN STYLE="font-style:italic">
<xsl:value-of select="calories"/> 嘿嘿
</SPAN>
</DIV>
</xsl:for-each>

</xsl:template>
</xsl:stylesheet>


xml文檔只有純粹的數據,如果需要顯示到html頁面中的話,一般需要使用定制的xsl文檔來解析,或者手工通過js來讀取xml中的值顯示到html中的dom樹中,當使用xsl文檔來解析時,相應的xml文檔中必須指定對應的xsl文檔才能正常顯示,但當有些程序動態輸出xml文檔時,并沒有指定相應的xsl文檔,這時就必須通過其它途徑來加載相應的xsl文檔來解析,當然,在服務器端輸出xml文檔時,通過一些xml api也可以實現,我這兒描述的是通過js來實現的一種方式。用這種方式的話,就拋開了服務器平臺的限制,服務器端只需要輸出相應的xml文檔(.net/j2ee都可以),并且將對應的xsl文檔輸出給客戶端(可以輸出流或直接在客戶端加載xsl文檔)。

這里有幾個需要注意的地方,我們一般是使用Msxml2.Document組件來加載xml文檔的,但當動態使用xsl解析xml文檔時,必須使用Msxml2.FreeThreadedDOMDocument這種自由線程的組件,同時使用MSXML2.XSLTemplate模板組件來加載xml,xsl數據,通過MSXML2.XSLTemplate的transform方法,就可以動態的用xsl來解析xml數據了,另外,IE5開始,系統默認的xml組件是msxml2,如果需要使用更新的msxml組件需要安裝更新的msxml組件包,并指定新的名稱,例如Msxml2.FreeThreadedDOMDocument.4.0,現在最新的msxml組件是6.0beta,可在M$網站下載。

演示:http://www.21cz.cn/xmltest/test.htm

xml文件查看:http://www.21cz.cn/xmltest/hello.xml
xsl文件查看:http://www.21cz.cn/xmltest/hello.xsl

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产日本欧美一区二区三区| 亚洲精品电影在线| 日韩av快播网址| 青青久久av北条麻妃黑人| 国产成人激情小视频| 欧美国产日韩精品| 欧美日韩亚洲成人| 亚洲精品丝袜日韩| 国产精品欧美一区二区| 日韩不卡中文字幕| 91成人在线观看国产| 欧美成人全部免费| 久久久国产视频91| 国产69精品久久久久9| 亚洲第一福利视频| 精品国产一区二区三区久久狼5月| 欧美制服第一页| 亚洲专区在线视频| 亚洲国产第一页| 亚洲国产福利在线| 亚洲第一页在线| 亚洲成人久久一区| 久热99视频在线观看| 国产精品久久久久国产a级| 亚洲欧美日韩另类| 亚洲电影免费在线观看| 上原亚衣av一区二区三区| 欧美性猛交xxxx免费看久久久| 精品国产乱码久久久久久婷婷| 高清一区二区三区日本久| 91精品久久久久久久久久另类| 成人日韩av在线| 亚洲视频网站在线观看| 亚洲人成绝费网站色www| 久久久久久尹人网香蕉| 久久激情视频免费观看| 亚洲高清久久网| 最近日韩中文字幕中文| 欧美大片大片在线播放| 亚洲图中文字幕| 日韩av第一页| 成人精品久久av网站| 久久成人综合视频| 国产成人精彩在线视频九色| 亚洲电影免费观看高清完整版在线观看| 国产欧美在线看| 欧美日韩国产精品一区二区不卡中文| 91干在线观看| 91九色视频导航| 亚洲视频自拍偷拍| 亚洲欧美国内爽妇网| 日韩欧亚中文在线| 免费97视频在线精品国自产拍| 欧美性猛交xxxxx免费看| 成人乱人伦精品视频在线观看| 精品亚洲aⅴ在线观看| 成人欧美一区二区三区在线湿哒哒| 欧美精品电影免费在线观看| 中文字幕亚洲欧美日韩2019| 法国裸体一区二区| 亚洲天堂男人天堂| 奇米成人av国产一区二区三区| 亚洲精品少妇网址| 色妞色视频一区二区三区四区| 91精品久久久久久久久久久久久| 国产精品国模在线| 久久久女人电视剧免费播放下载| 亚洲国产一区二区三区在线观看| 欧美视频二区36p| 欧美日韩激情网| 久久99精品国产99久久6尤物| 成人h视频在线| 国产在线观看不卡| 亚洲片在线观看| 国产91热爆ts人妖在线| 欧美日韩福利电影| 日韩av网站在线| 伊人伊人伊人久久| 国内精品久久久久久影视8| 911国产网站尤物在线观看| 亚洲国产天堂久久综合网| 亚洲免费一级电影| 日韩在线视频中文字幕| 日韩中文字幕不卡视频| 欧美一级电影在线| 91av在线网站| 亚洲精品国精品久久99热一| 亚洲免费一在线| 欧洲亚洲女同hd| 亚洲国产又黄又爽女人高潮的| 日韩精品免费综合视频在线播放| 欧美激情成人在线视频| 久久久综合免费视频| 亚洲一区二区免费在线| 久久久久久一区二区三区| 亚洲天堂精品在线| 亚洲人成在线电影| 欧美最顶级丰满的aⅴ艳星| 国产精品高清在线观看| 黄色成人在线免费| 国产中文字幕日韩| 国产精品日韩在线观看| 国产精品69精品一区二区三区| 亚洲精品丝袜日韩| 久久精品视频中文字幕| 欧美高清在线视频观看不卡| 国产女精品视频网站免费| 午夜剧场成人观在线视频免费观看| 欧美电影在线播放| 精品一区精品二区| 国产精品久久久久久超碰| 久久久人成影片一区二区三区观看| 欧美激情视频免费观看| 国外色69视频在线观看| 日韩av在线精品| 成人乱人伦精品视频在线观看| 国产香蕉精品视频一区二区三区| 91成人天堂久久成人| 精品中文字幕在线| 91精品国产91久久久久久不卡| 久久全球大尺度高清视频| 欧美大成色www永久网站婷| 欧美一级在线播放| 91亚洲国产成人精品性色| 欧美日韩国产精品一区二区三区四区| 亚洲性猛交xxxxwww| 欧美精品18videosex性欧美| 亚洲天堂色网站| xxxxxxxxx欧美| 欧美成人中文字幕| 欧美极品欧美精品欧美视频| 国产有码一区二区| 久久免费国产视频| 亚洲天堂av图片| 国产欧美 在线欧美| 国产精品九九九| 欧美黄色片免费观看| 欧美精品一区在线播放| 久久久久久久成人| 亚洲精品久久久久久久久久久| 国产精品尤物福利片在线观看| 亚洲欧美精品suv| 亚洲欧美国产va在线影院| 国产精品白嫩初高中害羞小美女| 亚洲开心激情网| 日韩视频在线观看免费| 欧美日韩亚洲精品一区二区三区| 国产欧美日韩精品丝袜高跟鞋| 成人av.网址在线网站| 91av视频在线免费观看| 亚洲成人网在线| 精品国产福利在线| 97超级碰碰碰久久久| 国产精品日本精品| 亚洲a∨日韩av高清在线观看| 久久久久亚洲精品国产| 亚洲欧美激情四射在线日| 777午夜精品福利在线观看| 91av在线不卡| 久久视频在线免费观看| 欧美xxxx综合视频| 欧美日韩免费在线| 精品中文字幕乱| 91av视频在线观看|