当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > 我在使用C#中Treeview与解析XML遇到的问题

ASP.NET
asp.net Linq TO Sql 分页方法
asp.net 用XML生成放便扩展的自定义树
asp.ent下合并两个结构相同的DataTable
asp.net 遍历repeater中的控件的几种方式
asp.net 处理原文件中过长的viewstate代码
asp.net下遍历页面中所有的指定控件的代码
获取创建Membership的数据库创建脚本
asp.net AJAX注册类
asp.net 处理F5刷新页面重复提交页面的一个思路
ASP.NET 缓存分析和实践浅析提高运行效率
asp.net 读取并显示excel数据的实现代码
ASP.NET中常用的用来输出JS脚本的类
ASP.NET中内嵌页面代码的一个问题
asp.net(C#)操作excel(上路篇)
一个基于Asp.Net MVC的权限方案
ASP.NET实例教程:51job网站地区选择功能
ASP.NET教程:友好的Html和JS适合SEO
ASP.NET教程:使用.ashx文件去除重复内容
ASP.NET做SEO:制作架构清晰和更新及时的网站地图
ASP.NET优化:Sql注入和Html注入的黑帽SEO

ASP.NET 中的 我在使用C#中Treeview与解析XML遇到的问题


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 124 ::
收藏到网摘: n/a

 近日我在用C#将PDM中相关内容导入到TreeView的过程中,遇到一个很奇怪的问题,请各位大虾指点,谢谢!

private void ReadXml(string strFileName)
  {
   try
   {
         XmlDocument xmlDoc = new XmlDocument();
         xmlDoc.Load("c:\xxx.pdm");
         TreeNode rootNode = new TreeNode("PDM原始文档结构");
         trvXML.Nodes.Clear();
         this.trv_end.Nodes.Clear();
         tn_end2=new TreeNode("PDM表结构");
         trv_end.Nodes.Add(tn_end2);
         XmlNodeList rootList = xmlDoc.ChildNodes;
         foreach(XmlNode xmlnode in rootList)
         {
               TreeNode tn = new TreeNode(xmlnode.Name);
               if (xmlnode.HasChildNodes)
               {
                     rootNode.Nodes.Add(tn);
                     AnalyseXML(xmlnode, tn);
               }
         }
   
         this.trvXML.Nodes.Add(rootNode);
   }
   catch(Exception ex)
   {
         MessageBox.Show(ex.Message);
   }
   
  }

private void AnalyseXML(XmlNode node, TreeNode tnode)
  {
   try
   {
    XmlNodeList xnlAll = node.ChildNodes;
    TreeNode tn_end=new TreeNode();
    TreeNode tn=new TreeNode();
    string strChineseName="";
    bool TagFlag=false;
    bool TagFlag2=false;
    foreach(XmlNode snode in xnlAll)
    {
     //形成PDM原始文档功能树
     if(snode.NodeType==XmlNodeType.Text)
     {
      tn = new TreeNode(snode.Value+"["+snode.NodeType.ToString()+"]");
     }
     else
     {
      tn=new TreeNode(snode.Name+"("+snode.NodeType.ToString()+")");
     }
     //形成PDM原始文档功能树完毕
     //填充PDM表结构功能树
     if(snode.NodeType==XmlNodeType.Element&&snode.ParentNode.Name.Equals("o:Table"))
     {
      //获取表中文名
      if(snode.Name.Equals("a:Name"))
      {
       strChineseName=snode.FirstChild.Value;
      }
      //表英文名
      if(snode.Name.Equals("a:Code"))
      {