C#窗体间常用的几种传值方式及委托与事件详解

 更新时间:2019年06月14日 10:54:40   作者:陈彦斌  
这篇文章主要给大家介绍了关于C#窗体间常用的几种传值方式及委托与事件的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用小程序具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧

前言

窗体间的传值,最好使用委托方式传值,开始之前,我们先来说一下委托与事件的关系。

委托:是一个类。

事件:是委托类型的一个特殊实例,只能在类的内部触发执行。

首先创建2个窗体,这里我们以form1为发送窗体,form2为接收窗体

form1窗体


form2窗体

 

方式一(最简单的方式)

form1窗体代码

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;


namespace 事件的方式实现窗体间传值
{
 public partial class Form1 : Form
 {
 public Form1()
 {
  InitializeComponent();
 }
 public Form2 msgFrm { get; set; }
 private void Form1_Load(object sender, EventArgs e)
 {
  Form2 f2 = new Form2();
  msgFrm = f2;
  f2.Show();
 }

 private void btnSendMsg_Click(object sender, EventArgs e)
 {
  //对象内部的,字段或者元素属性最好不要直接让外部直接访问
  //最好是通过,设置的方法来控制一下
  msgFrm.SetTxt(this.txtMsg.Text);
  
 }
 }
}

form2窗体代码

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace 事件的方式实现窗体间传值
{
 public partial class Form2 : Form
 {
  public Form2()
  {
   InitializeComponent();
  }
  public void SetTxt(string txt)
  {
   this.txtMsg.Text = txt;
  }
 }
}

方式二(委托方式)

注:委托不熟悉的宝宝们,请自行查阅Func与Action,以及delegate三者区别,这里我们用系统内置的委托Action

form1窗体代码

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;


namespace 事件的方式实现窗体间传值
{
 public partial class Form1 : Form
 {
  public Form1()
  {
   InitializeComponent();
  }
  //定义委托
  public Action<string> afterMsgSend { get; set; }
  private void Form1_Load(object sender, EventArgs e)
  {
   Form2 f2 = new Form2();
   afterMsgSend += f2.SetTxt; //给系统内置的委托注册事件
   f2.Show();
  }

  private void btnSendMsg_Click(object sender, EventArgs e)
  {
   if (afterMsgSend == null)
   {
    return;
   }
   afterMsgSend(this.txtMsg.Text);
  }
 }
}

form2窗体代码

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace 事件的方式实现窗体间传值
{
 public partial class Form2 : Form
 {
  public Form2()
  {
   InitializeComponent();
  }
  public void SetTxt(string txt)
  {
   this.txtMsg.Text = txt;
  }
 }
}

方式三(事件方式,更安全哟)

TextBoxMsgChangeEventArg类继承EventArgs代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace 事件的方式实现窗体间传值
{
 public class TextBoxMsgChangeEventArg:EventArgs
 {
  public string Text { get; set; }
 }
}

form1窗体代码

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;


namespace 事件的方式实现窗体间传值
{
 public partial class Form1 : Form
 {
  public Form1()
  {
   InitializeComponent();
  }
  public event EventHandler AfterMsgChange;
  private void Form1_Load(object sender, EventArgs e)
  {
   Form2 f2 = new Form2();
   AfterMsgChange += f2.AfterTxtChange;
   f2.Show();
  }
  private void btnSendMsg_Click(object sender, EventArgs e)
  {
   AfterMsgChange(this, new TextBoxMsgChangeEventArg() { Text = this.txtMsg.Text });
  }
 }
}

form2窗体

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace 事件的方式实现窗体间传值
{
 public partial class Form2 : Form
 {
  public Form2()
  {
   InitializeComponent();
  }
  public void AfterTxtChange(object sender,EventArgs e)
  {
   //拿到父窗体传来的文本,强转数据类型
   TextBoxMsgChangeEventArg arg = e as TextBoxMsgChangeEventArg;
   this.SetTxt(arg.Text);
  }
 }
}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。

相关文章

  • C# 设计模式系列教程-命令模式

    C# 设计模式系列教程-命令模式

    在软件系统中,行为请求者与行为实现者通常是一种紧耦合的关系,但某些场合,比如需要对行为进行记录、撤销或重做、事务等处理时,这种无法抵御变化的紧耦合的设计就不太合适。
    2016-06-06
  • asp.net core 使用 tensorflowjs实现 face recognition的源代码

    asp.net core 使用 tensorflowjs实现 face recognition的源代码

    tensorflowjs,在该项目中使用了ml5js这个封装过的机器学习JavaScript类库, 使用起来更简单,本文给大家分享asp.net core 使用 tensorflowjs实现 face recognition的源代码,需要的朋友参考下吧
    2021-06-06
  • C#异常处理的技巧和方法

    C#异常处理的技巧和方法

    在本篇文章里小编给大家整理了关于C#异常处理的技巧和方法以及相关知识点,需要的朋友们学习下。
    2019-03-03
  • C#基于SerialPort类实现串口通讯详解

    C#基于SerialPort类实现串口通讯详解

    这篇文章主要为大家详细介绍了C#基于SerialPort类实现串口通讯,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01
  • C#以流方式读socket超时设置的实例

    C#以流方式读socket超时设置的实例

    这篇文章主要为大家详细介绍了C#以流方式读socket超时设置的实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-03-03
  • Silverlight将图片转换为byte的实现代码

    Silverlight将图片转换为byte的实现代码

    这篇文章主要介绍了Silverlight将图片转换为byte的实现代码,需要的朋友可以参考下
    2015-11-11
  • c#中设置快捷键

    c#中设置快捷键

    c#中设置快捷键...
    2007-03-03
  • C#程序员最易犯的编程错误

    C#程序员最易犯的编程错误

    这篇文章主要介绍了C#程序员最易犯的10个编程错误,了解这些错误能够更好地学习C#程序设计,感兴趣的小伙伴们可以参考一下
    2015-11-11
  • C#装箱和拆箱原理详解

    C#装箱和拆箱原理详解

    这篇文章通过图例主要介绍了C#装箱和拆箱原理,内容很简单,感兴趣的小伙伴们可以参考一下
    2015-10-10
  • 轻松学习C#的装箱与拆箱

    轻松学习C#的装箱与拆箱

    轻松学习C#的装箱与拆箱,在之前的文章简单的提到了轻松学习C#的装箱与拆箱,本文带着大家更加详细的介绍轻松学习C#的装箱与拆箱,感兴趣的小伙伴们可以参考一下
    2015-11-11

最新评论