国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 開發(fā) > XML > 正文

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

2024-09-05 20:54:33
字體:
供稿:網(wǎng)友

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

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

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


3.修改WebForm1.aspx.cs中內(nèi)容,在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,并設(shè)為工程首頁:

以下是引用片段:
<html>
<head>
<title></title>
</head>
<body>
<div id="resTree"></div>
<FONT face="宋體"></FONT><input type="button" value="http://www.56wlw.com/執(zhí)行" 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文檔中并沒有指定對應(yīng)的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文檔只有純粹的數(shù)據(jù),如果需要顯示到html頁面中的話,一般需要使用定制的xsl文檔來解析,或者手工通過js來讀取xml中的值顯示到html中的dom樹中,當(dāng)使用xsl文檔來解析時,相應(yīng)的xml文檔中必須指定對應(yīng)的xsl文檔才能正常顯示,但當(dāng)有些程序動態(tài)輸出xml文檔時,并沒有指定相應(yīng)的xsl文檔,這時就必須通過其它途徑來加載相應(yīng)的xsl文檔來解析,當(dāng)然,在服務(wù)器端輸出xml文檔時,通過一些xml api也可以實現(xiàn),我這兒描述的是通過js來實現(xiàn)的一種方式。用這種方式的話,就拋開了服務(wù)器平臺的限制,服務(wù)器端只需要輸出相應(yīng)的xml文檔(.net/j2ee都可以),并且將對應(yīng)的xsl文檔輸出給客戶端(可以輸出流或直接在客戶端加載xsl文檔)。

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

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

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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
国产男女无套在线播放| 国产夫妻视频| 高清视频一区二区三区四区| 国产三级自拍| 免费在线高清av| 国产一级片网站| 国产美女视频一区二区三区| 午夜在线视频播放| 在线亚洲精品自拍| 国产精品久久久久久精| 国产精品入口免费麻豆| 99爱视频在线观看| 九九色在线观看| 精品国产免费第一区二区| 秋霞av在线| 导航福利在线| 国产经典av| 亚洲图区综合| 免费中文字幕| 国产青草视频在线观看视频| 亚洲人av在线| 中文av字幕| 中文字幕在线视频观看| 永久免费在线观看| 国产区卡一卡二卡三乱码免费| 青草视频在线播放| 亚洲欧美自拍另类| 精品国产一区二区三区四区阿崩 | 国产中文在线视频| 精品国产一区二区三区不卡在线| 国产免费福利| a中文在线播放| 在线亚洲不卡| 精品视频vs精品视频| 精品乱码一区二区三四区视频| wwww亚洲| 亚洲人成影院在线| 一本久久精品| av网站大全在线| 在线免费观看黄色av| 国产免费av在线| 福利视频网站导航| 国产你懂的在线观看| 高潮毛片在线观看| 久久精品免视着国产成人| 麻豆精品传媒视频观看| www.狠狠| 国产美女自拍视频| 国产视频三级在线观看播放| 国产精品综合久久久久| 九九精品九九| 尤物视频网站在线观看| 国产精品偷乱一区二区三区| 高清av中文在线字幕观看1| 久热精品免费视频| 日本啊v在线| 成人福利视频导航| 最近中文字幕mv2018在线高清| 国产美女高潮一区二区三区| 国产一卡2卡3卡免费网站| 最近中文字幕大全中文字幕免费| 中文字幕在线看精品乱码| 国产国语**毛片高清视频 | 国产性一级片| 99reav| 亚洲永久免费网站| 超碰免费在线| 最近中文字幕在线中文视频| 国产高清视频免费最新在线| 四虎一区二区三区| 国产免费黄色| 亚洲精品在线视频免费| 中文字幕网站视频在线| 思思99精品视频在线观看| 国产特级嫩嫩嫩bbb| 日本啊v在线| 国产成免费视频| 国产卡一卡二卡三| 亚洲天堂电影在线观看| 国产网站在线播放| 欧美日韩视频精品二区| 国产福利资源| 欧美卡一卡二| 亚洲图区综合| 在线观看国产视频| 国产丝袜在线观看视频| 二区三区中文字幕| 日本a级黄色| av在线日韩国产精品| 国产成人亚洲综合小说区| 国产美女性感在线观看懂色av| a级在线观看| 亚洲尤物在线视频| 精品一区二区在线欧美| 97人人在线| 精品国产免费观看一区| 99热免费在线| 国产精品久久久精品a级小说| 国产美女性感在线观看懂色av| 日本欧洲一区| 欧美性猛交xxxx免费看久久| 亚洲成人在线播放| 在线激情小视频| 一区二区三区免费视频网站| 91最新在线| 亚洲男人的天堂成人| 在线看黄色av| 四虎中文字幕| 久热国产在线视频| 国产另类图片| 国产国语**毛片高清视频| 精品视频在线一区二区| 2019中文字幕在线视频| aaa大片在线观看| 三级小说一区| 丁香在线视频| 国产不卡一卡2卡三卡4卡5卡在线| 国产福利微拍精品一区二区| 在线中文av| 国产在线视频网站| 国产高潮又爽又无遮挡又免费| 国产黄a三级三级三级av在线看 | av在线免费播放| 开心婷婷激情五月| 国产日本在线| 美女永久在线网站| 国产黄a三级三级三级av在线看| 在线视频99| 欧美色第一页| 国产成人精品18| 久久综合第一页| 精品电影在线| 天堂在线亚洲| 人人干在线视频| 国产精品毛片一区二区三区四区 | 天堂在线免费av| 国产a级网站| 国产毛片毛片| 亚洲精品影院在线| 国产精品剧情一区二区三区 | av在线不卡免费| 国产三级自拍| 国产综合视频一区二区三区免费| 91最新在线| 中文字幕欧美日韩在线不卡| 欧美韩日国产| av在线免费播放| 精品入口蜜桃| 国产网站av| 国产资源在线看| 激情丁香婷婷| 免费高清视频日韩| 亚洲精品影视在线| 在线午夜视频| 精品视频二区三区| 国产超级va在线视频| 国产高清免费av在线| 国产精品秘入口| 国产激情视频一区二区三区| 中文字幕免费中文| 国产一二三区在线| 国产一级片在线播放| 最近中文字幕大全中文字幕免费| 国产在线一二| 好男人社区在线视频| 福利在线视频导航| 最近中文字幕mv2018在线高清| 国产女王在线**视频| 1区2区3区在线| 国产美女极品在线| 国产网红女主播精品视频| 国产精品18久久久久网站| 国产不卡视频| eeuss影院www在线播放| 欧美黑人乱大交ⅹxxxxx| 欧美日韩性视频一区二区三区| 欧美性xxxx交| 中文字幕一区免费| 国产黄大片在线观看画质优化| 国产一二三区在线视频| 精品麻豆一区二区三区| 天海翼中文字幕| 超碰免费在线观看| 国产三级在线| 一本大道五月香蕉| 国产麻豆高清视频在线第一页| 国产呻吟对白刺激无套视频在线| 精品黄色免费中文电影在线播放| 久久国产综合视频| 国产精品黄页网站在线播放免费| av一级在线| 国产偷窥老熟盗摄视频| а√资源新版在线天堂| 国产精品麻豆一区二区三区| 亚洲欧美中文字幕在线观看| 天堂资源中文在线| eeuss影院www在线播放| 国产丝袜在线| 国产精选在线视频拍拍拍| 亚洲videos|