灵活调用xsl来解析xml文档(js异步)

2016-02-19 21:45 12 1 收藏

今天给大家分享的是由图老师小编精心为您推荐的灵活调用xsl来解析xml文档(js异步),喜欢的朋友可以分享一下,也算是给小编一份支持,大家都不容易啊!

【 tulaoshi.com - Web开发 】

       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="宋体"/FONTinput 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解析文件名)

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

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

  breakfast-menu
    food
      nameBelgian Waffles/name
      price$5.95/price
      descriptionTwo of our famous Belgian Waffles 
        with plenty of real maple syrup./description
      calories650/calories
    /food
    food
      nameStrawberry Belgian Waffles/name
      price$7.95/price
      descriptionLight Belgian waffles covered with 
       strawberries and whipped cream./description
      calories900/calories
    /food
    food
      nameBerry-Berry Belgian Waffles/name
      price$8.95/price
      descriptionLight Belgian waffles covered 
        with an assortment of fresh berries 
        and whipped cream./description
      calories900/calories
    /food
    food
      nameFrench Toast/name
      price$4.50/price
      descriptionThick slices made from our homemade 
       sourdough bread./description
      calories600/calories
    /food
    food
      nameHomestyle Breakfast/name
      price$6.95/price
      descriptionTwo eggs, bacon or sausage, toast, 
        and our ever-popular hash browns./description
      calories950/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

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

  
       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

来源:http://www.tulaoshi.com/n/20160219/1627039.html

延伸阅读
标签: Web开发
随着Internet的发展,越来越多的信息进入互联网,信息的交换、检索、保存及再利用等迫切的需求使HTML这种最常用的标记语言已越来越捉襟见肘。HTML将数据内容与表现融为一体,可修改性、数据可检索性差,而XML借鉴了HTML与数据库、程序语言的优点,将内容与表现分开,不仅使检索更为方便,更主要的是用户之间数据的交换更加方便,可重用性更...
标签: PHP
用sax方式的时候,要自己构建3个函数,而且要直接用这三的函数来返回数据, 要求较强的逻辑。 在处理不同结构的xml的时候, 还要重新进行构造这三个函数,麻烦! 用dom方式,倒是好些,但是他把每个节点都看作是一个node,操作起来要写好多的代码, 麻烦! 网上有好多的开源的xml解析的类库, 以前看过几个,但是心里总是...
标签: Web开发
1、用JS调用Htm,主页面怎么写? 在body与/body之间合适位置写下这个代码: script language="JavaScript" src="head.js"  type="text/JavaScript"/script src="js文件名称和路径" 2、js文件怎么写? 比如:head.js内容这样写,把主页面里的htm需要转换成JS的代码,用JS语句“document.write”或“document.writeln”...
标签: Web开发
创建多个带有不同参数的存储过程(stored procedure)来完成同一个任务总是一个很大的负担。利用XML字符串向你的存储过程发送参数就能够简化这个任务;这也让COM组件的设计更简单。  实现这个目的的方法是将你的参数作为一个XML字符串来传递,并剖析XML来取回你所需要的数据,然后继续实现你所需要集成的功能。你不仅可以通过XM...
标签: Web开发
通过使用XSL,您可以向XML文档添加显示信息。 使用XSL显示XML XSL是首选的XML样式表语言。 XSL远比CSS更加完善。使用XSL的方法之一是在浏览器显示XML文件之前,先把它转换为HTML,正如以下的这些例子演示的那样: 查看XML文件: ?xml version="1.0" encoding="ISO-8859-1" ? - !-- Edited with XML Spy v2007 (http://www.altova.com) ...

经验教程

735

收藏

72
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部