当前位置: 首页 > 编程笔记 >

C#通过反射打开相应窗体方法分享

杨和蔼
2023-03-14
本文向大家介绍C#通过反射打开相应窗体方法分享,包括了C#通过反射打开相应窗体方法分享的使用技巧和注意事项,需要的朋友参考一下

C#单击菜单栏或工具栏时通过反射打开窗体的方法,可以以取代长长的if-else或switch-case语句。要点:将菜单或工具栏项的名称设置为与相应窗体名称相同(关键)。

private void MenuItem_Click(object sender, EventArgs e)
{
   ToolStripMenuItem menuItem = (ToolStripMenuItem)sender;
   Form form = (Form)Assembly.Load(“您的程序集名称”).CreateInstance(“窗体命名空间. “+ menuItem.Name); //注意: 窗体命  名空间后面一定要加一个点
   form.MdiParent = this; //如果是Mdi窗体的话请加这一行
   form.Show();
}

如果我们的一个窗体里有N个窗体,或者是有一Tree需要对应的调用N个窗体话,如果使用IF ELse方法可能会很麻烦,

一般可能我会们这样写 

private void button3_Click(object sender, EventArgs e)
    {
      //获取单击的Button名称
      string btnname = ((Button)sender).Name;
      if (btnname == "button1")
      {
        //处理窗体
      }
      else if (btnname == "button2")
      {
        //处理窗体
      }
      else
      {
        //处理窗体
      }
    }

这样也不是不可 行,但是如果100多个上千个就不行了,
可以说超过10个就不好玩了,但是如果使用反射就很方便 ,只需要几行代码就可以的,
看下面的方法吧

/// <summary> 
    /// 打开新的子窗体 
    /// </summary> 
    /// <param name="strName">窗体的类名</param> 
    /// <param name="AssemblyName">窗体所在类库的名称</param>  
    html" target="_blank">public static void CreateForm(string strName, string AssemblyName)
    {
      string path = AssemblyName;//项目的Assembly选项名称 
      string name = strName; //类的名字 
      Form doc = (Form)Assembly.Load(path).CreateInstance(name);
      doc.Show();
    }

    private void button1_Click(object sender, EventArgs e)
    {
      //获取单击的Button名称
      string btnname = ((Button)sender).Text;
      CreateForm("WindowsFormsApplication1." + btnname, "WindowsFormsApplication1");
    }

有了上面的方法,只要我们的用户控件Text和窗体的类名一样就可能实现动态加载了,当然如果有的同志说我的Text要用汉字怎么办,那就再换个属性啊,比如Name或者是其他属性都可以。总之肯定比你一个一个的去写要方便很多

以上所述就是本文的全部内容了,希望大家能够喜欢。

 类似资料:
  • 本文向大家介绍C#通过反射获取当前工程中所有窗体并打开的方法,包括了C#通过反射获取当前工程中所有窗体并打开的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了C#通过反射获取当前工程中所有窗体并打开的方法。分享给大家供大家参考。具体实现方法如下: 希望本文所述对大家的C#程序设计有所帮助。

  • 问题内容: 现在我有 它反射性地打印大多数信息,但会创建一个空的正文。如何增加Java的反射性来打印方法主体? 问题答案: 如何增加Java的反射性来打印方法主体? 恐怕很难。 首先,原始源代码很可能对正在运行的程序不可用。通常,开发人员不要在二进制JAR中包含源代码。(即使这样做,也不能保证它们将成为“真实”来源。) 通常,您可以通过将类的FQN转换为字节码文件并使用类classloader将文

  • 要 动态获取一个对象方法的信息,首先需要通过下列方法之一创建一个 类型的对象或者数组。 getMethods() getMethods(String name,Class<?> …parameterTypes) getDeclaredMethods() getDeclaredMethods(String name,Class<?>...parameterTypes) 如果是访问指定的构造方法,需要

  • 在处理高度并发的单例类的单元测试时,我偶然发现了以下奇怪的行为(在JDK 1.8.0\U 162上测试): main()方法的最后两行在INSTANCE的值上不一致-我猜JIT完全摆脱了该方法,因为该字段是静态final。删除final关键字可以使代码输出正确的值。 撇开你对单例的同情(或缺乏同情)不谈,暂时忘记像这样使用反射是在自找麻烦——我的假设是正确的吗?JIT优化是罪魁祸首?如果是这样的话

  • 为了能够 动态获取对象构造方法的信息,首先需要通过下列方法之一创建一个 类型的对象或者数组。 getConstructors() getConstructor(Class<?>…parameterTypes) getDeclaredConstructors() getDeclaredConstructor(Class<?>...parameterTypes) 如果是访问指定的构造方法,需要根据该构

  • 如何使用反射来区分类重载方法,例如: <代码>方法()和<代码>方法(int-arg) 并调用此函数: 它返回错误,这意味着默认情况下选择没有参数的方法。如果我调用没有int参数的方法,它将工作。我问如何区分重载的方法?我已经阅读了的文档https://docs.oracle.com/javase/8/docs/api/java/lang/Class.html还有一个关于SO的旧帖子,但两个来源都