需求: 页面上有两个下拉框,显示游戏大区 和游戏服务器,当游戏大区改变时,游戏服务器也跟着改变

界面部分html代码

  1. <tr class="tkSigUser">
  2. <th>游戏大区:</th>
  3. <td>
  4. <asp:DropDownList ID="gamezonedll" runat="server"></asp:DropDownList>
  5. </td>
  6. <td></td>
  7. </tr>
  8. <tr class="tkSigUser">
  9. <th>服务器名:</th>
  10. <td>
  11. <select id="serverddl" name="serverdll"></select>
  12. <input type="hidden" name="serverName" />
  13. </td>
  14. <td></td>
  15. </tr>

xml文档内容

在ready部分 页面初始化时根据大区ID加载服务器信息 ,当大区变更时change事件,服务器信息变化。

  1. var xmDoc;//用于装载请求到的xml文档
  2.  
  3. 使用ajax 异步请求xml文档并处理
  4.  
  5. $(document).ready(function () {
  6.  
  7. $.ajax({
  8. url: "../js/xinhejiguang.xml",
  9. dataType: 'xml',
  10. type: 'get',
  11. error: function () {
  12. alert("加载区服信息失败");
  13. },
  14. success: function (xml) {
  15. xmlDoc = xml; //将xml保存起来,可以在其他地方接着使用,不用再次请求
  16. var gamezoneid = $("#<%=gamezonedll.ClientID %> option:selected").val();
  17. findServer(gamezoneid);
  18. }
  19.  
  20. });
  21.  
  22. $("#<%=gamezonedll.ClientID %>").change(function () {
  23. var id = $("#<%=gamezonedll.ClientID %> option:selected").val();
  24. $("#serverddl").empty();
  25. findServer(id);
  26. });
  27.  
  28. });
  1. //根据大区ID,查找服务器信息并添加到 服务器节点
  2. function findServer(zoneid) {
  3. var gameServerList = $(xmlDoc).find("game[id='10123']").find("gameZone[id='"+zoneid+"']").find("gameServer");
  4. gameServerList.each(function (index, content) {
  5. var serverid = $(content).attr("id");
  6. var servername = $(content).attr("name");
  7. $("#serverddl").append("<option value='" + serverid + "'>" + servername + "</option>");
  8. });
  9.  
  10. }

程序采用的是web form ,.net 2.0平台。所以使用了服务器端控件。开始的设想是 大区 、服务器都使用web服务器控件,在page_Load 方法中初始化加载区服信息,

用jquery 异步改变服务器的值,但是在提交时出现 回发或回调参数无效 的错误,

网上查找基本回答都是一样的 http://hi.baidu.com/chy_daima/item/733e963fd63dccb8134b148c

但是这些方法都不好用,简单方法 禁用 EnableEventValidation="false" ,会导致在behindcode 中获取不到你修改的控件的值,只是获取原来的值。

开始用js取新的服务器信息是用下边的方法:

webform 在前台js中调用后台代码的方法:

首先在Page_Load 中 写上

  1. Ajax.Utility.RegisterTypeForAjax(typeof(xinhejiguang));

xinhejiguang 是后台的类名

然后再后台写方法

  1. [Ajax.AjaxMethod(Ajax.HttpSessionStateRequirement.Read)]
  2. public string GetGameServer(string zoneId)
  3. {
  4. XmlDocument jiguang = new XmlDocument();
  5. string filepath = AppDomain.CurrentDomain.BaseDirectory + "zc\\js\\xinhejiguang.xml";
  6. jiguang.Load(filepath);
  7.  
  8. XmlNode zonenode = jiguang.SelectSingleNode("/company/gameList/game[@name='极光世界']/gameZoneList/gameZone[@id=" + zoneId + "]");
  9. XmlNodeList serverlist = zonenode.SelectNodes("gameServerList/gameServer");
  10. StringBuilder buider = new StringBuilder();
  11.  
  12. foreach (XmlNode server in serverlist)
  13. {
  14. string serverid = server.Attributes["id"].Value;
  15. string servername = server.Attributes["name"].Value;
  16. buider.AppendFormat("{0}:{1}|", serverid, servername);
  17. }
  18.  
  19. buider.Remove(buider.Length - , );
  20. return buider.ToString();
  21. }

那么 在前台 js 就可以通过

  1. var id = 11159;
  2. var result = xinhejiguang.GetGameServer(id).value;

来调用后台程序,得到服务器信息。然后再进行split 分割,加载。

这个方法对于用js调用服务器端的方法很好用。

Jquery 操作xml 文档的方法的更多相关文章

  1. 操作XML文档遇到的XMLNS问题及解决方法 (C# 和 PHP)

    原文:操作XML文档遇到的XMLNS问题及解决方法 (C# 和 PHP) 不管是用 PHP 还是 C#, 在操作 XML 的时候我们除了一个节点一个节点去取值之外, 还有一个非常方便的表达式, 就是 ...

  2. 四种生成和解析XML文档的方法详解(介绍+优缺点比较+示例)

    众所周知,现在解析XML的方法越来越多,但主流的方法也就四种,即:DOM.SAX.JDOM和DOM4J 下面首先给出这四种方法的jar包下载地址 DOM:在现在的Java JDK里都自带了,在xml- ...

  3. 操作xml文档的常用方式

    1.操作XML文档的两种常用方式: 1)使用XmlReader类和XmlWriter类操作 XmlReader是基于数据流的,占用极少的内存,是只读方式的,所以速度极快.只能采用遍历的模式查找数据节点 ...

  4. 四种生成和解析XML文档的方法详解

    众所周知,现在解析XML的方法越来越多,但主流的方法也就四种,即:DOM.SAX.JDOM和DOM4J 下面首先给出这四种方法的jar包下载地址 DOM:在现在的Java JDK里都自带了,在xml- ...

  5. jquery-7 jquery中的文档处理方法有哪些(方法的参数表示功能增强)

    jquery-7 jquery中的文档处理方法有哪些(方法的参数表示功能增强) 一.总结 一句话总结:多看参考文档,多看主干目录.一般的功能分两个方法来实现,一个对应标签,一个对应标签和事情,比如克隆 ...

  6. C#XmlHelper帮助类操作Xml文档的通用方法汇总

    前言 该篇文章主要总结的是自己平时工作中使用频率比较高的Xml文档操作的一些常用方法和收集网上写的比较好的一些通用Xml文档操作的方法(主要包括Xml序列化和反序列化,Xml文件读取,Xml文档节点内 ...

  7. XML DOM (Document Object Model) 定义了访问和操作 XML 文档的标准方法。

    XML DOM DOM 把 XML 文档视为一种树结构.通过这个 DOM 树,可以访问所有的元素.可以修改它们的内容(文本以及属性),而且可以创建新的元素.元素,以及它们的文本和属性,均被视为节点. ...

  8. 用ORM的思想操作XML文档,一个对象就搞定不要太简单。滚蛋吧!XmlDocument、XmlNode、Xml***……

    大家有没有这样的感受,一涉及XML文档操作就得百度一遍.是不是非!常!烦!.各种类型,各种方法,更别提为了找到一个节点多费劲.本来想写个XML操作的工具方法,写了两行一想既然XML文档是有规律的,如果 ...

  9. C#操作XML文档---基础

    增查改删代码如下 public void CreateXML() { XmlDocument xml = new XmlDocument(); xml.AppendChild(xml.CreateXm ...

随机推荐

  1. 2328: [HNOI2011]赛车游戏 - BZOJ

    先把一定要减的费用先减掉,就是b*s*len(上坡路),下坡路就设一个初速度,使耗油为0,如果没油了,就无法到达 然后考虑加速 对于长度为len的路,增加v的速度需要len*a*v的油,与len成正比 ...

  2. 2336: [HNOI2011]任务调度 - BZOJ

    一道随机算法的题目 随便用什么随机算法 首先我们可以想到枚举类型3的最终类型,然后再做 先贪心出一个较优的序列,首先我们知道肯定是在A机器上先做完类型1的事件再做类型2的事件,机器B也类似,因为这些没 ...

  3. 明晰三种常见存储技术:DAS、SAN和NAS

    随着企业网络应用的时间和应用的数据量的加大,企业已经感觉到存储容量和性能落后与网络的应用发展需求,特别是流媒体企业,在这种应用条件下满足用户的存储需求的技术应用诞生,DAS.NAS和SAN三种存储技术 ...

  4. linux 安装firefox

    从火狐官网下载的firefox-9.0.1.tar.bz2解压后,进入firefox文件夹,执行./firefox会提示缺少库,故采用yum安装Firefox9.1.切换到root用户 su - 2. ...

  5. MapperScannerConfigurer(转)

    转:http://blog.csdn.net/ranmudaofa/article/details/8508028 原文:http://www.cnblogs.com/daxin/p/3545040. ...

  6. POJ 1562 && ZOJ 1709 Oil Deposits(简单DFS)

    题目链接 题意 : 问一个m×n的矩形中,有多少个pocket,如果两块油田相连(上下左右或者对角连着也算),就算一个pocket . 思路 : 写好8个方向搜就可以了,每次找的时候可以先把那个点直接 ...

  7. POJ 1061 青蛙的约会(扩展欧几里德)

    点我看题目 题意 : 中文题不详述. 思路 : 设经过s步后两青蛙相遇,则必满足(x+m*s)-(y+n*s) = K*L(k = 0,1,2....) 变形得:(n-m)*s+K*L = x-y ; ...

  8. MAT使用总结

    最近在做项目的时候遇到一个内存泄漏,最后通过MAT定位了问题, 先介绍一下MAT的一些基本概念: Shallow Heap:对象本身占用内存的大小,不包含对其他对象的引用,也就是对象头加成员变量(不是 ...

  9. Java Socket实战之一 单线程通信

    本文地址:http://blog.csdn.net/kongxx/article/details/7259436 现在做Java直接使用Socket的情况是越来越少,因为有很多的选择可选,比如说可以用 ...

  10. Qt xcode wrapper Qios OpenFly

    https://github.com/richardmg/QtWrapper https://github.com/richardmg/qios https://github.com/richardm ...