c#使用Dataset读取XML文件动态生成菜单的方法

本文实例讲述了c#使用Dataset读取XML文件动态生成菜单的方法。分享给大家供大家参考。具体实现方法如下:

Step 1:Form1 上添加一个ToolStripContainer控件

Step2:实现代码

private void Form2_Load(object sender, EventArgs e)
{
 CMenuEx menu = new CMenuEx();
 string sPath = "D://Menu.xml";//xml的内容
 if (menu.FileExit())
 {
  menu.LoadAllMenu(sPath, toolStripContainer1);
  //读取xml来加载菜单
 }
 else
 { MessageBox.Show("XML文件加载失败!"); }
}
/// <summary>
/// 菜单读取类
/// </summary>
public class CMenuEx
{
 private string _Path;
 /// <summary>
 /// 设置XML配置文件路径
 /// </summary>
 public string Path
 {
 get { return _Path; }
 set { _Path = value; }
 }
 /// <summary>
 /// 判断文件是否存在
 /// </summary>
 /// <returns>文件是否存在</returns>
 public bool FileExit()
 {
 if (File.Exists(_Path))
 { return true; }
 else return false;
 }
 /// <summary>
 /// 加载菜单
 /// </summary>
 /// <param name="menuStrip">母菜单对象</param>
 public void LoadAllMenu(string sXmlPath, ToolStripContainer pToolStripContainer)
 {
 DataSet ds = new DataSet();
 ds.ReadXml(sXmlPath, XmlReadMode.Auto);
 string ToolStripPanelType = "TopToolStripPanel";
 //查找所有最初一级的菜单
 DataView dvMenuOptions = new DataView(ds.Tables["MenuOptions"], "ParentLevel=ID and ToolStripPanelType='" + ToolStripPanelType + "'", "DisplayOrder Asc", DataViewRowState.CurrentRows);
 string sParentLevel = "";
 ToolStripPanel tspTop = pToolStripContainer.TopToolStripPanel;
 tspTop.Dock = DockStyle.Top;
 ToolStrip tsTop = new ToolStrip();
 tspTop.Join(tsTop); //绑定ToolStrip
 foreach (DataRowView rvMain in dvMenuOptions)
 //循环得到主菜单
 {
  sParentLevel = rvMain["ParentLevel"].ToString();
  ToolStripMenuItem tsItemParent = new ToolStripMenuItem();
  tsItemParent.Text = rvMain["Text"].ToString();
  tsItemParent.Name = rvMain["Name"].ToString();
  tsTop.Items.Add(tsItemParent);//添加父菜单
  //查找父菜单下的所有子菜单
  DataView dvSub = new DataView(ds.Tables["MenuOptions"], "ParentLevel<>ID and ParentLevel='" + sParentLevel + "'", "DisplayOrder", DataViewRowState.CurrentRows);
  foreach (DataRowView rvSub in dvSub)
  {
  ToolStripMenuItem itemSub = new ToolStripMenuItem();
  itemSub.Text = rvSub["Text"].ToString() + " " + rvSub["ShortCutKeys"].ToString();
  //为菜单添加单击事件
  itemSub.Click += new EventHandler(toolSubItem_Click);
  //菜单响应函数
  itemSub.Name = rvSub["Method"].ToString();
  tsItemParent.DropDownItems.Add(itemSub);
  }
 }
 }
 //自定义消息响应函数
 void toolSubItem_Click(object sender, EventArgs e)
 {
 //创建菜单调用方法类的实例
 MenuMethod menuMethod = new MenuMethod();
 Type type = menuMethod.GetType();
 //动态获取方法对象
 MethodInfo mi = type.GetMethod(((ToolStripMenuItem)sender).Name);
 //调用指定方法
 if (mi != null)
 {
  mi.Invoke(menuMethod, null);
 }
 }
 /// <summary>
 /// 菜单的方法列表类
 /// </summary>
 class MenuMethod
 {
 public void New()
 {
  MessageBox.Show("New");
 }
 public void Open()
 {
  MessageBox.Show("Open");
 }
 }
}

附:xml内容:

<?xml version="1.0" encoding="GB2312" ?>
<Menus>
 <MenuOptions>
 <ID>3766e9a2-7955-44eb-ad87-91ccb798baa7</ID>
 <ParentLevel>3766e9a2-7955-44eb-ad87-91ccb798baa7</ParentLevel>
 <DisplayOrder>1</DisplayOrder>
 <ToolBarItemType>ToolStripButton</ToolBarItemType>
 <ToolStripItemDisplayStyle>ImageAndText</ToolStripItemDisplayStyle>
 <ToolStripPanelType>TopToolStripPanel</ToolStripPanelType>
 <ToolStripDisplayPosition>1</ToolStripDisplayPosition>
 <TDTVisible>True</TDTVisible>
 <ShortCutKeys />
 <Text>文档工具栏</Text>
 <Name>DocTool</Name>
 <Image />
 <Expression />
 <Assembly />
 </MenuOptions>
 <MenuOptions>
 <ID>fd75638f-6c10-473d-b6e6-bdfd2c7931d6</ID>
 <ParentLevel>3766e9a2-7955-44eb-ad87-91ccb798baa7</ParentLevel>
 <DisplayOrder>0</DisplayOrder>
 <ToolBarItemType>ToolStripButton</ToolBarItemType>
 <ToolStripItemDisplayStyle>Image</ToolStripItemDisplayStyle>
 <ToolStripPanelType />
 <ToolStripDisplayPosition />
 <TDTVisible>True</TDTVisible>
 <ShortCutKeys>Ctrl+N</ShortCutKeys>
 <Text>新建地图文档</Text>
 <Method>New</Method>
 <Image>/img/New.ico</Image>
 <Expression />
 <Assembly />
 </MenuOptions>
 <MenuOptions>
 <ID>9c6238d5-b47d-4b08-933c-ea7c74f6b586</ID>
 <ParentLevel>3766e9a2-7955-44eb-ad87-91ccb798baa7</ParentLevel>
 <DisplayOrder>1</DisplayOrder>
 <ToolBarItemType>ToolStripButton</ToolBarItemType>
 <ToolStripItemDisplayStyle>Image</ToolStripItemDisplayStyle>
 <ToolStripPanelType />
 <ToolStripDisplayPosition />
 <TDTVisible>True</TDTVisible>
 <ShortCutKeys>Ctrl+O</ShortCutKeys>
 <Text>打开文档</Text>
 <Method>Open</Method>
 <Image>/ico/open.ico</Image>
 <Expression>Com.Linjon.ArcGIS.PlugIn.File.OpenDocCmd</Expression>
 <Assembly>Com.Linjon.ArcGIS.PlugIn.dll</Assembly>
 </MenuOptions>
</Menus>

希望本文所述对大家的C#程序设计有所帮助。

(0)

相关推荐

  • C# XML操作 代码大全(读XML,写XML,更新,删除节点,与dataset结合等)第1/2页

    已知有一个XML文件(bookstore.xml)如下: Corets, Eva 5.95 1.插入节点 往节点中插入一个节点: 复制代码 代码如下: XmlDocument xmlDoc=new XmlDocument(); xmlDoc.Load("bookstore.xml"); XmlNode root=xmlDoc.SelectSingleNode("bookstore");//查找 XmlElement xe1=xmlDoc.CreateElement(

  • C#实现读取DataSet数据并显示在ListView控件中的方法

    本文实例讲述了C#实现读取DataSet数据并显示在ListView控件中的方法.分享给大家供大家参考.具体如下: /*lvStudentList为ListView控件名 */ DataSet ds = new DataSet(); ds = student.QueryStudents(); //查询表的信息 int rowCount, columnCount,i,j; rowCount = ds.Tables[0].Rows.Count; columnCount = ds.Tables[0].

  • C#将Excel中的数据转换成DataSet

    使用C#在不借助第三方插件的情况下将Excel中的数据转换成DataSet /// <summary> /// EXCEL数据转换DataSet /// </summary> /// <param name="filePath">文件全路径</param> /// <param name="search">表名</param> /// <returns></returns>

  • C#实现利用泛型将DataSet转为Model的方法

    本文实例讲述了C#实现利用泛型将DataSet转为Model的方法.分享给大家供大家参考.具体如下: 因为网站需要用C#开发,习惯了java的泛型,所以看了一下C#下,也可以这样做,随便写了一个. public static List<T> PutAllVal<T>(T entity, DataSet ds) where T : new() { List<T> lists = new List<T>(); if (ds.Tables[0].Rows.Coun

  • C#实现DataSet内数据转化为Excel和Word文件的通用类完整实例

    本文实例讲述了C#实现DataSet内数据转化为Excel和Word文件的通用类.分享给大家供大家参考,具体如下: 前不久因为项目的需要写的一个C#把DataSet内数据转化为Excel和Word文件的通用类,这些关于Excel.Word的导出方法,基本可以实现日常须要,其中有些方法可以把数据导出后 生成Xml格式,再导入数据库!有些屏蔽内容没有去掉,保留下来方便学习参考用之. 最后请引用Office相应COM组件,导出Excel对象的一个方法要调用其中的一些方法和属性. using Syste

  • C#中遍历DataSet数据集对象实例

    本文介绍C#上如何使用DataSet对象,并对DataSet对象中的表进行遍历,同时遍历表中的每一行,遍历每一行的每一列的值. 首先什么是DataSet,在C#中,Dataset就像一个数据库,其中可以有多个表(Table),也可以只有一个表,每个表中有行(DataRow)和列(DataColumn).使用DataRow[DataColumn]的形式可以得到某行某列数据值. 复制代码 代码如下: //下面例子中使用foreach来遍历DataSet中的所有表,对于每个表遍历所有的记录,并输出每一

  • C#中DataSet转化为实体集合类的方法

    本文实例讲述了C#中DataSet转化为实体集合类的方法,分享给大家供大家参考.具体实现方法如下: 复制代码 代码如下: /// <summary> /// DataSet转换为实体类 /// </summary> /// <typeparam name="T">实体类</typeparam> /// <param name="p_DataSet">DataSet</param> /// <

  • C#通过DataSet读写xml文件的方法

    本文实例讲述了C#通过DataSet读写xml文件的方法.分享给大家供大家参考.具体实现方法如下: DataSet ds = new DataSet(); //读取Xml文件 ds.ReadXml(Server.MapPath("xml/song.xml")); //生成Xml文件 ds.WriteXml(Server.MapPath("xml/song_bak.xml")); 希望本文所述对大家的C#程序设计有所帮助.

  • C#使用DataSet Datatable更新数据库的三种实现方法

    本文以实例形式讲述了使用DataSet Datatable更新数据库的三种实现方法,包括CommandBuilder 方法.DataAdapter 更新数据源以及使用sql语句更新.分享给大家供大家参考之用.具体方法如下: 一.自动生成命令的条件 CommandBuilder 方法 a)动态指定 SelectCommand 属性 b)利用 CommandBuilder 对象自动生成 DataAdapter 的 DeleteCommand.InsertCommand 和 UpdateCommand

  • c#使用Dataset读取XML文件动态生成菜单的方法

    本文实例讲述了c#使用Dataset读取XML文件动态生成菜单的方法.分享给大家供大家参考.具体实现方法如下: Step 1:Form1 上添加一个ToolStripContainer控件 Step2:实现代码 private void Form2_Load(object sender, EventArgs e) { CMenuEx menu = new CMenuEx(); string sPath = "D://Menu.xml";//xml的内容 if (menu.FileExi

  • asp.net使用DataSet的ReadXml读取XML文件及Stream流的方法

    本文实例讲述了asp.net使用DataSet的ReadXml读取XML文件及Stream流的方法.分享给大家供大家参考,具体如下: string strxml = "<xml><m><a>1</a><b>2</b></m><m><a>11</a><b>22</b></m><m><a>111</a><

  • spring mvc 读取xml文件数据库配置参数的方法

    本文主要介绍怎么通过属性注入与构造器注入实现把我们项目中要用到的数据库参数放到xml文件里面去,方便部署. spring mvc 4.2.6项目 SQL Server 2008数据库 本文介绍的主要使用ApplicationContext以及其实现类实现.主要用到的是ClassPathXmlApplicationContext. ClassPathXmlApplicationContext:从类路径ClassPath中寻找指定的XML配置文件,找到并装载 完成ApplicationContext

  • JS使用ajax从xml文件动态获取数据显示的方法

    本文实例讲述了JS使用ajax从xml文件动态获取数据显示的方法.分享给大家供大家参考.具体分析如下: 下面的JS代码通过ajax检索xml文件的内容动态展示到网页,真个页面无刷新 <!DOCTYPE html> <html> <head> <script> function loadXMLDoc(url) { var xmlhttp; var txt,x,xx,i; if (window.XMLHttpRequest) {// code for IE7+,

  • Android使用xml文件资源定义菜单实现方法示例

    本文实例讲述了Android使用xml文件资源定义菜单实现方法.分享给大家供大家参考,具体如下: 使用 XML 文件定义菜单 Android 提供了创建菜单的方式,一种是在 Java 代码中创建,一种是使用XML 文件定义.上面的实例都是 Java 创建菜单,在 Java 存在如下大学. 实现效果如下: 具体实现: 一.在 /res 下建立 /menu文件夹 二.在menu文件夹下建立:menu_main.xml: <?xml version="1.0" encoding=&qu

  • ASP.NET中读取XML文件信息的4种方法与示例代码

    方法一 :使用XML控件 <% @ Page Language="C#"%> <html> <body>          <h3><font face="Verdana">读取XML方法一</font></h3>        <from runat=server>         <asp:Xml id="xml1" DocumentSour

  • JS通过ajax动态读取xml文件内容的方法

    本文实例讲述了JS通过ajax动态读取xml文件内容的方法.分享给大家供大家参考.具体分析如下: 下面的JS代码读取note.xml文件,并填充显示相关字段 HTML文件代码如下 <!DOCTYPE html> <html> <head> <script> function loadXMLDoc(url) { var xmlhttp; if (window.XMLHttpRequest) {// code for IE7+, Firefox, Chrome,

  • C#从文件流读取xml文件到DataSet并显示的方法

    本文实例讲述了C#从文件流读取xml文件到DataSet并显示的方法.分享给大家供大家参考.具体实现方法如下: 复制代码 代码如下: DataSet ds= new DataSet (); FileStream fs = new FileStream (Server.MapPath=("somexml.xml"),FileMode.Open,FileAccess.Read); ds.ReadXml (fs); DataGrid1.DataSource = ds; DataGrid1.D

  • JS读取XML文件数据并以table形式显示数据的方法(兼容IE与火狐)

    本文实例讲述了JS读取XML文件数据并以table形式显示数据的方法.分享给大家供大家参考,具体如下: 先看xml文件: <?xml version="1.0" standalone="yes"?> <student> <stuinfo> <stuName>张秋丽</stuName> <stuSex>女 </stuSex> <stuAge>18</stuAge>

随机推荐