如何创建用户控件(Windows Form .NET)

本文介绍如何向项目添加用户控件,然后将该用户控件添加到窗体。 创建一个可重用的用户控件,并使其兼具视觉吸引力和功能性。 新控件对 TextBox 控件和 Button 控件进行分组。 用户选择该按钮时,将清除文本框中的文本。 有关用户控件的详细信息,请参阅用户控件概述

将用户控件添加到项目

在 Visual Studio 中打开 Windows Form 项目后,使用 Visual Studio 模板创建用户控件:

  1. 在 Visual Studio 中,找到“项目资源管理器”窗口。 右键单击项目并选择“添加”>“用户控件(Windows Form)”

    右键单击 Visual Studio 解决方案资源管理器,将用户控件添加到 Windows Form 项目

  2. 将控件的名称设置为“可清除TextBox”,然后按“添加”

    在 Visual Studio 中为 Windows Form 添加项目对话框

创建用户控件后,Visual Studio 将打开设计器:

Visual Studio 中用于 Windows Form 的用户控件设计器

设计可清除文本框

用户控件由构成控件组成,这些控件是你在设计图面上创建的控件,就像设计窗体的方式一样。 按照以下步骤添加和配置用户控件及其构成控件:

  1. 打开设计器后,用户控件设计图面应为选定对象。 如果不是,请单击设计图面以将其选中。 在“属性”窗口中,设置下列属性

    属性 Value
    MinimumSize 84, 53
    大小 191, 53
  2. 添加 Label 控件。 设置以下属性:

    属性
    名称 lblTitle
    位置 3, 5
  3. 添加 TextBox 控件。 设置以下属性:

    属性
    名称 txtValue
    定位点 Top, Left, Right
    位置 3, 23
    大小 148, 23
  4. 添加 Button 控件。 设置以下属性:

    属性
    名称 btnClear
    定位点 Top, Right
    位置 157, 23
    大小 31, 23
    文本

    此控件应如下所示:

    支持 Windows Form 的 Visual Studio,显示刚刚设计的用户控件。

  5. F7 打开 ClearableTextBox 类的代码编辑器。

  6. 执行以下代码更改:

    1. 在代码文件顶部导入 System.ComponentModel 命名空间。

    2. DefaultEvent 特性添加到该类中。 此属性设置在设计器中双击控件时使用者生成的事件。 使用者是声明和使用此控件的对象。 有关属性的详细信息,请参阅特性 (C#)特性概述 (Visual Basic)

      using System.ComponentModel;
      
      namespace UserControlProject
      {
          [DefaultEvent(nameof(TextChanged))]
          public partial class ClearableTextBox : UserControl
      
      Imports System.ComponentModel
      
      <DefaultEvent("TextChanged")>
      Public Class ClearableTextBox
      
    3. 添加将 TextBox.TextChanged 事件转发给使用者的事件处理程序:

      [Browsable(true)]
      public new event EventHandler? TextChanged
      {
          add => txtValue.TextChanged += value;
          remove => txtValue.TextChanged -= value;
      }
      
      <Browsable(True)>
      Public Shadows Custom Event TextChanged As EventHandler
          AddHandler(value As EventHandler)
              AddHandler txtValue.TextChanged, value
          End AddHandler
          RemoveHandler(value As EventHandler)
              RemoveHandler txtValue.TextChanged, value
          End RemoveHandler
          RaiseEvent(sender As Object, e As EventArgs)
      
          End RaiseEvent
      End Event
      

      请注意,此事件在其上声明了 Browsable 属性。 将 Browsable 应用于事件或属性后,当在设计器中选择该控件时,它可以控制该项在“属性”窗口中是否可见。 在本例中,true 作为参数传递给指示事件应可见的属性。

    4. 添加名为 Text 的字符串属性,以将 TextBox.Text 属性转发给使用者:

      [Browsable(true)]
      public new string Text
      {
          get => txtValue.Text;
          set => txtValue.Text = value;
      }
      
      <Browsable(True)>
      Public Shadows Property Text() As String
          Get
              Return txtValue.Text
          End Get
          Set(value As String)
              txtValue.Text = value
          End Set
      End Property
      
    5. 添加名为 Title 的字符串属性,以将 Label.Text 属性转发给使用者:

      [Browsable(true)]
      public string Title
      {
          get => lblTitle.Text;
          set => lblTitle.Text = value;
      }
      
      <Browsable(True)>
      Public Property Title() As String
          Get
              Return lblTitle.Text
          End Get
          Set(value As String)
              lblTitle.Text = value
          End Set
      End Property
      
  7. 切换回 ClearableTextBox 设计器,然后双击 btnClear 控件以生成 Click 事件的处理程序。 为处理程序添加以下代码,以清除 txtValue 文本框:

    private void btnClear_Click(object sender, EventArgs e) =>
        Text = "";
    
    Private Sub btnClear_Click(sender As Object, e As EventArgs)
        txtValue.Text = ""
    End Sub
    
  8. 最后,在解决方案资源管理器窗口中,右键单击项目并选择“生成”以生成项目。 应不会有任何错误,生成完成后,控件 ClearableTextBox 会显示在工具箱中以供使用。

下一步是使用窗体中的控件。

示例应用程序

如果在最后一节中创建了一个新项目,则有一个名为 Form1 的空白 Form,否则创建一个新窗体

  1. 在“解决方案资源管理器”窗口中,双击窗体以打开设计器。 窗体的设计图面应为选中状态。

  2. 将窗体的 Size 属性设置为 432, 315

  3. 打开“工具箱”窗口,然后双击“可清除TextBox”控件。 此控件应列在以项目命名的部分下。

  4. 再次双击“可清除TextBox”控件以生成第二个控件

  5. 返回到设计器并将控件分开,以便完全显示它们。

  6. 选择一个控件并设置以下属性:

    属性
    名称 ctlFirstName
    位置 12, 12
    大小 191, 53
    游戏 First Name
  7. 选择另一个控件并设置以下属性:

    属性
    名称 ctlLastName
    位置 12, 71
    大小 191, 53
    Title Last Name
  8. 返回到“工具箱”窗口,向窗体添加标签控件,然后设置以下属性

    属性
    名称 lblFullName
    位置 12, 252
  9. 接下来,需要为这两个用户控件生成事件处理程序。 在设计器中,双击 ctlFirstName 控件。 此操作将生成 TextChanged 事件的事件处理程序,并打开代码编辑器。

  10. 切换回设计器并双击 ctlLastName 控件以生成第二个事件处理程序。

  11. 切换回设计器并双击窗体的标题栏。 此操作会生成 Load 事件的事件处理程序。

  12. 在代码编辑器中,添加 UpdateNameLabel 方法。 此方法将合并两个名称以创建一条消息,并将该消息分配给 lblFullName 控件。

    private void UpdateNameLabel()
    {
        if (string.IsNullOrWhiteSpace(ctlFirstName.Text) || string.IsNullOrWhiteSpace(ctlLastName.Text))
            lblFullName.Text = "Please fill out both the first name and the last name.";
        else
            lblFullName.Text = $"Hello {ctlFirstName.Text} {ctlLastName.Text}, I hope you're having a good day.";
    }
    
    Private Sub UpdateNameLabel()
        If String.IsNullOrWhiteSpace(ctlFirstName.Text) Or String.IsNullOrWhiteSpace(ctlLastName.Text) Then
            lblFullName.Text = "Please fill out both the first name and the last name."
        Else
            lblFullName.Text = $"Hello {ctlFirstName.Text} {ctlLastName.Text}, I hope you're having a good day."
        End If
    End Sub
    
  13. 对于这两个 TextChanged 事件处理程序,请调用 UpdateNameLabel 方法:

    private void ctlFirstName_TextChanged(object sender, EventArgs e) =>
        UpdateNameLabel();
    
    private void ctlLastName_TextChanged(object sender, EventArgs e) =>
        UpdateNameLabel();
    
    Private Sub ctlFirstName_TextChanged(sender As Object, e As EventArgs) Handles ctlFirstName.TextChanged
        UpdateNameLabel()
    End Sub
    
    Private Sub ctlLastName_TextChanged(sender As Object, e As EventArgs) Handles ctlLastName.TextChanged
        UpdateNameLabel()
    End Sub
    
  14. 最后,从窗体的 Load 事件调用 UpdateNameLabel 方法:

    private void Form1_Load(object sender, EventArgs e) =>
        UpdateNameLabel();
    
    Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load
        UpdateNameLabel()
    End Sub
    

运行项目并输入名字和姓氏:

Windows Form 应用,其中包含使用用户控件和标签创建的两个文本框。

尝试按 按钮重置其中一个文本框。