Form2(子窗体)调用Form1(父窗体)的控件

一直在寻找Vs c# 跨窗体数据传递,通俗点讲就是Form2(子窗体)调用Form1(父窗体)的控件,在一篇博客上找到,名称为:Winform跨窗体操作控件(使用委托),感谢大神的分享,转载到博客,时时提醒自己!!!

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/e62ces0iem/article/details/73477176
div id=“article_content” class=“article_content clearfix”>


Winform跨窗体操作控件是winform开发中很常见的形式,最常见且简单有效的方式便是使用委托的方式来进行操作,下面我将通过一个小实例来说明如何使用委托跨窗体实现控件操作。

实例介绍:两个窗体,Form1按钮打开Form2,然后在Form2的TextBox输入值在Form1的TextBox中显示出来。


一、项目结构

Form1窗体设计:

Form2窗体设计:

二、代码实现

在Form2的代码中声明一个委托(写在Form2类外)->

 public delegate void ChangeForm1TextBoxValue(string txt);

然后在Form2类内写一个委托事件->

public event ChangeForm1TextBoxValue ChangeTextBoxValue;

双击Form2的textbox给Form2的textbox添加值变化出发事件,并在此事件中调用委托事件->

private void textBox1_TextChanged(object sender, EventArgs e)
{
          ChangeTextBoxValue(this.textBox1.Text);//执行委托实例  
}

Form2的完整代码如下:

复制代码
using System;
using System.Windows.Forms;

namespace Test.FormsApp
{
public delegate void ChangeForm1TextBoxValue(string txt);
public partial class Form2 : Form
{
public event ChangeForm1TextBoxValue ChangeTextBoxValue;
public Form2()
{
InitializeComponent();
}

    <span style="color:rgb(0,0,255)">private</span> <span style="color:rgb(0,0,255)">void</span> textBox1_TextChanged(<span style="color:rgb(0,0,255)">object</span> sender, EventArgs e)
    {
        ChangeTextBoxValue(<span style="color:rgb(0,0,255)">this</span>.textBox1.Text);<span style="color:rgb(0,128,0)">//</span><span style="color:rgb(0,128,0)">执行委托实例  </span>
    }
}

}

复制代码

然后我们切换到Form1的代码

button点击事件实例化Form2并调用Form2的委托事件->

        private void button1_Click(object sender, EventArgs e)
        {
            Form2 f2 = new Form2();
            f2.ChangeTextBoxValue += F2_ChangeTextBoxValue;
            f2.Show();
        }

在下面声明委托事件的操作方法->

        private void F2_ChangeTextBoxValue(string txt)
        {
            this.textBox1.Text = txt;
        }

上述步骤在输入+=号时可以双击两下Tab键,IDE(编译器)会自动将事件补全~

Form1的完整代码如下:

 

复制代码
using System;
using System.Windows.Forms;

namespace Test.FormsApp.NETFramework461
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}

    <span style="color:rgb(0,0,255)">private</span> <span style="color:rgb(0,0,255)">void</span> button1_Click(<span style="color:rgb(0,0,255)">object</span> sender, EventArgs e)
    {
        Form2 f2 = <span style="color:rgb(0,0,255)">new</span> Form2();
        f2.ChangeTextBoxValue += F2_ChangeTextBoxValue;
        f2.Show();
    }

    <span style="color:rgb(0,0,255)">private</span> <span style="color:rgb(0,0,255)">void</span> F2_ChangeTextBoxValue(<span style="color:rgb(0,0,255)">string</span> txt)
    {
        <span style="color:rgb(0,0,255)">this</span>.textBox1.Text = txt;
    }
}

}

复制代码

 

到这里,我们的实现基本完成,下面进入测试!

三、效果测试

然后在Form2的textbox中输入值

可以看到值已经实时显示到Form1的textbox中。

测试结果达到预期效果,项目实现成功!

一起成长,共同学习~

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值