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

首頁 > 開發 > XML > 正文

調用xsl來解析xml文檔(js異步)

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

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="執行" 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網站下載。

 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
亚洲大香人伊一本线| 亚洲欧美精选| 久青青在线观看视频国产| 在线免费观看高清视频色| 国产福利视频在线观看| 精精国产xxxx视频在线| 日本久久国产| 国产一区二区影视| 国产精品麻豆一区二区三区| 国产aⅴ超薄肉色丝袜交足| av高清资源| 欧美韩日国产| 超碰在线97国产| 国产精品视频h| 欧美色欧美亚洲另类二区精品| 天天操夜夜添| 国产三区四区在线观看| 一色桃子av在线| 国产小视频在线观看| www.狠狠色.com| 国产天堂视频| av在线免费观看网| 国产精品一区二三区| 国产大学生粉嫩无套流白浆| а√天堂8资源在线官网| 成人日韩欧美| 国产91足控脚交在线观看| 国产对白国语对白| 欧美激情福利视频在线观看免费| 免费在线播放av| 伊人福利在线| 国产一区精品| 最近中文字幕mv2018在线高清| www.91在线播放| 在线国产小视频| 国产极品嫩模在线视频一区| 国产一区在线视频观看| www.大网伊人| 亚洲综合在线网| 精品麻豆视频| 国产精品xxx电影| 国产一二区视频| 国产永久免费高清在线观看视频 | 国产香蕉免费精品视频| 爱福利在线视频| 亚洲尤物在线视频| 中文字幕高清av| 黄色国产网站在线观看| 7777在线| 91www在线观看| 亚洲夜夜综合| 亚洲欧美中文字幕在线观看| 99福利在线| av在线中文| 免费国产阿v视频在线观看| 永久免费在线观看| 日本亚洲欧美| 麻豆国产在线视频| 九色视频网站| 综合图区亚洲白拍在线 | 日本中文字幕视频| 免费电影网站在线视频观看福利| 日本高清中文字幕在线| 99视频免费在线观看| 日韩av成人| 国产不卡在线| √天堂资源中文www| 96精品视频| 天天插天天干| 丁香六月婷婷| 在线中文免费视频| 日本福利在线观看| 中文字幕免费中文| 91免费日韩| 成年人在线观看| аⅴ成人天堂中文在线| 日本综合一区二区三区| 福利资源在线久| 最近中文字幕大全中文字幕免费| 91xxx在线观看| 国产偷激情在线| 国产精品666| www.香蕉视频在线观看| 国产一区精品| 天天噜天天色| 国产视频一二| 男人天堂亚洲| 国产视频一二区| 毛片视频免费观看| 亚洲天堂视频在线观看免费| 国产在线一二三区| av丝袜在线| 国产三级在线看| www.狠狠插| av网站大全在线观看| 天堂在线中文资源| av在线free| 18 激情视频在线| 国产网红在线| 中文字幕在线影院| 男人操女人免费网站| 在线一二三区| 2018中文字幕在线| 国产精品四虎| 国产秒拍福利视频露脸| www.eeuss影院| 亚洲欧美久久婷婷爱综合一区天堂| 国产www网站| 国产福利在线观看| 国产欧美黑人| 精品乱码一区二区三四区视频| 国产一级在线| 国产麻豆视频| 中文字幕麻豆| 国产色婷婷在线| 91www在线观看| 99reav在线| 免费特级黄毛片| 九九热在线播放| 国产真实伦在线观看| 国产九色视频| 中文字幕中文字幕在线中高清免费版| 男人天堂99| 国产欧美日本亚洲精品一4区| 午夜视频免费在线观看| 国产二区三区在线| 亚洲www色| 青草av在线| 国产欧美一区二区三区小说| 在线观看电影av| 成人免费一区二区三区视频网站| 国产网站av| www.eeuss影院| 国产成人亚洲综合小说区| 牛牛在线精品视频| 精品国产一区二区三区不卡在线| 免费看的毛片| av网站在线播放| 国产网站av| 久久亚洲国产成人亚| 91在线网站| √天堂8资源中文在线| 精品国产一区二区三区不卡在线| 久久久久久日本一区99| 在线国产1区| 国产极品视频| 国产麻豆精品入口在线观看| 亚洲视频精品在线观看| 国产三级视频在线看| 九九热在线视频免费观看| 伊人中文在线| 2020亚洲男人天堂| 国产福利在线免费观看| 午夜在线小视频| 久久精品蜜桃| 青青青青在线| h网站免费在线观看| 国产日韩欧美第一页| 国产精品自拍亚洲| 久久久久国产精品嫩草影院| 日本一卡二卡四卡精品| av福利在线| 天天激情综合| 青青草中文字幕| xxxxx中文字幕| 日本亚洲欧美| 欧美日韩不卡中文字幕在线| 人成在线免费视频| 欧美性猛交p30| 九九热免费视频| 国产美女在线看| 国产麻豆精品一区二区三区v视界| а√资源新版在线天堂| 青青草原国产在线| 九九热免费在线视频| 中文字幕有码在线视频| 国产无套粉嫩白浆在线2022年| 国产亚洲精品午夜高清影院| 国产成人午夜| 欧美日韩一区二区三区在线播放 | 国产女人在线观看| 国产精品久久麻豆| 亚洲精品aaaa| 午夜免费视频在线国产| 国产图片综合| 亚洲精品一区中文字幕电影| 免费在线看v| 精品亚洲成a人片在线观看| 欧美亚洲系列| 国产精品jvid在线观看| 日本亚洲欧美| 国产区视频在线| 免费av不卡在线观看| 国产精品入口麻豆免费观看| av在线free| 91啦中文在线| 中文字幕色视频| 欧美96在线| 亚洲国产成人综合| 国产蜜臀av在线播放|