猿问

C#中带有参数的“ UserControl”构造函数

叫我疯了,但我是那种喜欢带参数的构造函数(如果需要)的人,而不是没有参数后再设置属性的构造函数。我的思考过程:如果需要属性来实际构造对象,则应将其放入构造函数中。我有两个优点:


我知道在构造对象时(没有错误/异常),我的对象很好。

它有助于避免忘记设置某些属性。

在表单/用户控件开发方面,这种心态开始伤害我。想象一下UserControl:


public partial class MyUserControl : UserControl

{

  public MyUserControl(int parm1, string parm2)

  {

    // We'll do something with the parms, I promise

    InitializeComponent();

  }

}

在设计时,如果将其UserControl放在表单上,则会得到Exception:


无法创建组件'MyUserControl'...

System.MissingMethodException-没有为此对象定义无参数构造函数。


在我看来,唯一的解决方法是添加默认构造函数(除非其他人知道一种方法)。


public partial class MyUserControl : UserControl

{

  public MyUserControl()

  {

    InitializeComponent();

  }


  public MyUserControl(int parm1, string parm2)

  {

    // We'll do something with the parms, I promise

    InitializeComponent();

  }

}

不包括无参数构造函数的全部目的是避免使用它。而且我什DesignMode至不能使用该属性来做类似的事情:


public partial class MyUserControl : UserControl

{

  public MyUserControl()

  {

    if (this.DesignMode)

    {

      InitializeComponent();

      return;

    }


    throw new Exception("Use constructor with parameters");

  }

}

这也不起作用:


if (LicenseManager.UsageMode == LicenseUsageMode.Designtime)

很好,继续前进...


我有我的无参数构造函数,可以将其放在表单上,表单的形式InitializeComponent如下:


private void InitializeComponent()

{

  this.myControl1 = new MyControl();


  // blah, blah

}

并相信我,因为我做到了(是的,忽略了Visual Studio生成的注释),我尝试弄乱了,然后将参数传递给,InitializeComponent以便可以将它们传递给的构造函数MyControl。


这导致我这样:


public MyForm()

{

  InitializeComponent(); // Constructed once with no parameters


  // Constructed a second time, what I really want

  this.myControl1 = new MyControl(anInt, aString);  

}

对于UserControl要在构造函数中使用with参数的情况,我必须添加第二个不需要的构造函数?并实例化控件两次?


我觉得我一定做错了。有什么想法吗?意见?保证(希望)?


莫回无
浏览 910回答 3
3回答

互换的青春

有关Windows窗体工作方式的设计决策或多或少排除了Windows窗体组件的参数化.ctors。您可以使用它们,但是当您这样做时,便会超出公认的机制。而是Windows窗体更喜欢通过属性初始化值。如果未广泛使用,这是一种有效的设计技术。不过,这有一些好处。易于客户使用。客户端代码不需要跟踪一堆数据,它可以立即创建某些内容,并以有意义(如果不感兴趣)的结果来查看它。设计者易于使用。通常,设计器代码更清晰,更易于解析。阻止单个组件中异常的数据依赖关系。(尽管甚至Microsoft都用吹灭了它SplitContainer)表单中也有很多支持,可以与设计师一起使用此技术。,和这样的东西DefaultValueAttribute,使您有机会以最小的努力提供丰富的客户体验。DesignerSerializationVisibilityAttributeBrowsableAttribute(这并不是在Windows窗体中为客户体验做出的唯一折衷。抽象基类组件也可能变得毛茸茸。)我建议坚持使用无参数构造函数,并在Windows窗体设计原则中进行工作。如果UserControl必须执行一些实际的先决条件,则将它们封装在另一个类中,然后通过一个属性将该类的实例分配给您的控件。这也将更好地分离关注点。

宝慕林4294392

不幸的是,这是一个经常发生的设计问题,而不仅仅是控制空间。在很多情况下,即使无参构造函数不是理想的,您也需要有无参构造函数。例如,如果没有无参数构造函数,则许多值类型IMO会更好,但是创建一个可以那样工作的类型是不可能的。在这些情况下,您仅需以最佳方式设计控件/组件。使用合理的(最好是最常用的)默认参数可以极大地帮助您,因为您至少(希望)可以使用良好的值初始化组件。另外,尝试以某种方式设计组件,以便在生成组件后可以更改这些属性。使用Windows Forms组件通常很好,因为在安全加载时间之前,您几乎可以做任何事情。再次,我同意-这不是理想的选择,但这只是我们必须与之共处和解决的问题。
随时随地看视频慕课网APP
我要回答