javascript读取XML文件实现程序

 代码如下 复制代码

 

1、通过JS读取XML文件,主要是判断各个浏览器 

View Code

// 加载xml文档
       var loadXML = function (xmlFile) {
            var xmlDoc;
            if (window.ActiveXObject) {
                xmlDoc = new ActiveXObject('Microsoft.XMLDOM');//IE浏览器
                xmlDoc.async = false;
                xmlDoc.load(xmlFile);
            }
            else if (isFirefox=navigator.userAgent.indexOf("Firefox")>0) { //火狐浏览器
            //else if (document.implementation && document.implementation.createDocument) {//这里主要是对谷歌浏览器进行处理
                xmlDoc = document.implementation.createDocument('', '', null);
                xmlDoc.load(xmlFile);
            }
            else{ //谷歌浏览器
              var xmlhttp = new window.XMLHttpRequest();
                xmlhttp.open("GET",xmlFile,false);
                xmlhttp.send(null);
                if(xmlhttp.readyState == 4){
                xmlDoc = xmlhttp.responseXML.documentElement;
                }
            }

            return xmlDoc;
        }

        // 首先对xml对象进行判断
      var  checkXMLDocObj = function (xmlFile) {
            var xmlDoc = loadXML(xmlFile);
            if (xmlDoc == null) {
                alert('您的浏览器不支持xml文件读取,于是本页面禁止您的操作,推荐使用IE5.0以上可以解决此问题!');
                window.location.href = '../err.html';

            }
            return xmlDoc;
        }

2、将读取到的xml文件中的数据显示到html文档上

View Code
    <script type="text/javascript" language="javascript">
        var xmlDoc = checkXMLDocObj('../openClass.xml');//读取到xml文件中的数据
        var a = document.getElementsByTagName("a");//获取所有的A标签
        $(document).ready(function () {
              var nodes;
            if($.browser.msie){ // 注意各个浏览器之间的区别
             nodes = xmlDoc.getElementsByTagName('collage')[0].childNodes; //读取XML文件中需要显示的数据
             }
             else if (isFirefox=navigator.userAgent.indexOf("Firefox")>0){
                nodes = xmlDoc.getElementsByTagName('collage')[0].children; //读取XML文件中需要显示的数据
             }
             else{
                nodes = xmlDoc.getElementsByTagName('resource');
             }
           
             for (var i = 0; i < a.length; i++) {
                if (a[i].parentNode.nodeName == "SPAN") {
                    for (var j = 0; j < nodes.length; j++) {
                        var resource = nodes[j];
                        var url = resource.getAttribute('url');
                        var href=$(a[i]).attr("href");
                        if (href == url) {
                            var count = resource.getAttribute('click');
                            var span = document.createElement("div");
                            var str = document.createTextNode("点击率:" + count);
                            span.appendChild(str);
                            var div = a[i].parentNode.parentNode;
                            div.appendChild(span);
                            break;
                        }
                    }
                }
            }
        });
                $(function(){ //通过get请求,将点击率增加
                 $(a).mousedown(function(){
                             var href = $(this).attr("href");
                            $.get("../receive.ashx",{url:href,rd:Math.random()}, function (msg) {
                           
                            });
                        })
        }) 
    </script>  

3、通过更新ashx文件在服务器上更新对应的xml文件

 

public void ProcessRequest(HttpContext context)
    {
        context.Response.ContentType = "text/plain";
        string src = context.Request.QueryString["url"];
        string path = context.Server.MapPath("openClass.xml"); //打开xml文件
        XmlDocument xmlDoc = new XmlDocument();
        xmlDoc.Load(path); //注意不能用Xmlload()方法
        XmlNodeList nodeslist = xmlDoc.SelectNodes("/collage/resource"); //找到对应的节点
        foreach (XmlNode node in nodeslist)
        {
            XmlElement xe = (XmlElement)node;
            if (xe.GetAttribute("url") == src)
            {
                int count = int.Parse(xe.GetAttribute("click"));
                count = count + 1;
                xe.SetAttribute("click", count.ToString()); //更新内容
            }
        }
        xmlDoc.Save(path); //保存
      
    }

时间: 2024-10-29 18:56:24

javascript读取XML文件实现程序的相关文章

javascript读取Xml文件做一个二级联动菜单示例

 这篇文章主要介绍了使用javascript中读取Xml文件做成的一个二级联动菜单,需要的朋友可以参考下  代码如下: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">  <html>  <head>  <title>menu2level.html</title>  <meta http-equiv="content-type&quo

用javascript读取xml文件读取节点数据_javascript技巧

下面代码是读取的节点数据,还有一种情况是读取节点属性数据. <head> <title></title> <script type="text/javascript"> var objLength = null; var xmlHttp; var strurl = ""; function ajaxrequst() { if (window.ActiveXObject) { xmlHttp = new ActiveXO

在使用JavaScript读取xml文件出问题了

问题描述 这是我的php目录:C:Program FilesCodeGearDelphi for PHP2.0vclgeneric_controlsBlockParameterEditView.php,我想在这个php下读取E:trunkappCompilerplantsdemofoundry_demoplant.xml内的节点.可是似乎只能读和php文件在相同的目录或者是其子目录下的plant.xml文件的节点.请问大家喔怎么读取E盘下的plant.xml文件呢. 解决方案 首先,我要明确的告

javascript读取Xml文件做一个二级联动菜单示例_javascript技巧

复制代码 代码如下: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>menu2level.html</title> <meta http-equiv="content-type" content="text/html; charset=UTF-8"> &

javascript 遍历xml文件实现程序

 代码如下 复制代码 <script>          function getXmldoc(xmlfile){     //创建Xmldocument对象,使用方法:传入xml文件名即可.                 var xmlDoc;   // 判断浏览器是不是IE                 if (window.ActiveXObject) {   xmlDoc=new ActiveXObject("Microsoft.XMLDOM");   }  

javascript读取xml文件,读不到数据

问题描述 我利用Ajax来进行翻页,在Servlet中从数据库获取数据,数据写入out对象中,最后的数据格式为:<response>  <scoreinfo>   <stuno>2004150201</stuno>   <stuname>张三</stuname>   <course>语文</course>   <score>89</score>     </scoreinfo>

C#写一个读写XML文件的程序

问题描述 写一程序可以修改写入读取XML文件的程序 解决方案 解决方案二:学习一下:解决方案三: 解决方案四:XDocument,XmlDocument,XmlSerializer都可以,看需求了.解决方案五://利用递归获取xml的所有节点(元素也是节点)publicvoidRecurseXml(XmlNoderoot,intindex){if(root==null){return;}if(rootisXmlElement){tbxContent.Text+=root.Name.PadLeft

JavaScript操作XML文件之XML读取方法

 本文实例讲述了JavaScript操作XML文件之XML读取方法.分享给大家供大家参考.具体分析如下: 假设我们现在要读取下面的 info.xml 文件 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 <?xml version="1.0" encoding="gb2312"?> <root> <data id="1"> <name

vba 读取xml文件读到一定的行数行程序运行就出现Not Responding

问题描述 vba 读取xml文件读到一定的行数行程序运行就出现Not Responding 自己写的vba代码读取xml文件时读到一定的行数就出现Not Responding,不知如何解决,求大神解答!!!! 解决方案 你怎么写的代码?建议你引用msxml6.0库,用它来解析. http://jenniferamanda.iteye.com/blog/1684939