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

  委托:是一个类。

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

首先创建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#窗体间常用的几种传值方式、以及委托与事件的详细介绍的更多相关文章

  1. Vue中常用的几种传值方式

    Vue中常用的几种传值方式 1. 父传子 父传子的实现方式就是通过props属性,子组件通过props属性接收从父组件传过来的值,而父组件传值的时候使用 v-bind 将子组件中预留的变量名绑定为da ...

  2. Vue中常用的三种传值方式

    父传子 父子组件的关系可以总结为prop向下传递,事件向上传递.父组件通过prop给子组件下发数据,子组件通过事件给父组件发送消息. 父组件: <template> <div> ...

  3. iOS 页面间几种传值方式(属性,代理,block,单例,通知)

    第二个视图控制器如何获取第一个视图控制器的部分信息 例如 :第二个界面中的lable显示第一个界面textField中的文本 这就需要用到属性传值.block传值 那么第一个视图控制器如何获的第二个视 ...

  4. Vue 常用三种传值方式

    Vue常用的三种传值方式: 父传子 子传父 非父子传值 引用官网一句话:父子组件的关系可以总结为 prop 向下传递,事件向上传递.父组件通过 prop 给子组件下发数据,子组件通过事件给父组件发送消 ...

  5. django之创建第7-6-第三种传值方式

    1.创建bar.html文件 <!DOCTYPE html> <html lang="en"> <head> <meta charset= ...

  6. django之创建第7-5-第二种传值方式(time/1232/xiaodneg)

    1.修改views文件 def foo(request,myID,myName): t = loader.get_template("foo.html") user = {&quo ...

  7. 【温故知新】——原生js中常用的四种循环方式

    一.引言 本文主要是利用一个例子,讲一下原生js中常用的四种循环方式的使用与区别: 实现效果: 在网页中弹出框输入0   网页输出“欢迎下次光临” 在网页中弹出框输入1   网页输出“查询中……” 在 ...

  8. C#窗体间通讯的几种处理方法

    应用程序开发中,经常需要多窗体之间进行数据通信,写几个例子,把几种常用的通信方式总结一下: 主窗体Form1是一个ListBox,单击选中某列时,弹出窗体Form2,Form2中两个控件,一个是Tex ...

  9. 浅谈Asp.Net中的几种传值方式

    一.使用Querystring Querystring是一种非常简单的传值方式,其缺点就是会把要传送的值显示在浏览器的地址栏中,并且在此方法中不能够传递对象.如果你想传递一个安全性不是那么太重要或者是 ...

随机推荐

  1. Python 从入门到进阶之路(七)

    之前的文章我们简单介绍了一下 Python 中异常处理,本篇文章我们来看一下 Python 中 is 和 == 的区别及深拷贝和浅拷贝. 我们先来看一下在 Python 中的双等号 == . == 是 ...

  2. ASP.NET Core Web 应用程序开发期间部署到IIS自定义主机域名并附加到进程调试

    想必大家之前在进行ASP.NET Web 应用程序开发期间都有用到过将我们的网站部署到IIS自定义主机域名并附加到进程进行调试. 那我们的ASP.NET Core Web 应用程序又是如何部署到我们的 ...

  3. HashMap数据结构与实现原理解析(干货)

    HashMap 数据结构解析: HashMap内部使用hash表(本质是一个数组见图一) HashMap使用hash算法计算得到存放的索引位置,以此来加快查询速度,(比ArrayList还要快) 同样 ...

  4. layui table 分页 序号始终从”1“开始解决方法

    在用Layui table 分页显示数据,用 type:"numbers" 进行显示序号有以下的问题 1.表格自带的分页,page:true 这种分页,在切换页面的时候序号可以正常 ...

  5. JavaScript动态加载script方式引用百度地图API,Uncaught ReferenceError: BMap is not defined

    百度地图官网文档介绍使用JSSDK时,仅提供了2种引入方式: script引入 异步加载 实际工作场景中仅某一两个页面或者只是单纯有功能需要用到百度地图,所以没有必要在 index.html 中全局引 ...

  6. leaflet 实现克里金插值功能(附源码下载)

    前言 leaflet 入门开发系列环境知识点了解: leaflet api文档介绍,详细介绍 leaflet 每个类的函数以及属性等等 leaflet 在线例子 leaflet 插件,leaflet ...

  7. P1005 Spell It Right

    # P1005 Spell It Right 原题 Given a non-negative integer N, your task is to compute the sum of all the ...

  8. Http相关小知识点笔记咯~

    协议 先来说说什么是协议,协议其实指的是通信协议(Communications Protocol),也称传输协议.Wiki中的描述的是这样的,通信协议定义了通信中的语法学,语义学和同步规则以及可能存在 ...

  9. 微信小程序官方文档中表单组建button部分有关function(type)中type的个人理解

    官方文档关于button组件的简介 xml页面挺容易理解,但js部分起初对整体写的形式都不太理解,随着逐渐阅读代码基本理解了 xml页面代码: <button type="defaul ...

  10. sso单点登录系统的压力测试

    环境:vmware centos7.4 2cpu 2核心 工具:ab压力测试工具 测试对象:sso单点登录系统 电脑:win10 4核 项目环境:flask+uwsgi+nginx(uwsgi 2进程 ...