zoukankan      html  css  js  c++  java
  • windows form (窗体) 之间传值小结

    windows form之间传值,我总结了有四个方法:全局变量、属性、窗体构造函数和delegate

    第一个全局变量:

    这个最简单,只要把变量描述成static就可以了,在form2中直接引用form1的变量,代码如下:

    form1中定义一个static变量public static int i= 9 ;

    Form2中的钮扣按钮如下:

    private void button1_Click(object sender, System.EventArgs e)

    {

        textBox1.Text = Form1.i.ToString();

    }

     

    第二个方法是利用属性,请详见我的博客:

    http://blog.csdn.net/tjvictor/archive/2006/06/04/772711.aspx

     

    第三个方法是用构造函数:

    Form1 的button按钮这样写:

    private void button1_Click(object sender, System.EventArgs e)

    {

        Form2 temp = new Form2( 9 );

        temp.Show();

    }

     

    Form2 的构造函数这样写:

    public Form2( int i )

    {

        InitializeComponent();

        textBox1.Text = i.ToString();

    }

     

    第四个方法是用delegate,代码如下:

    Form2中先定义一个delegate

    public delegate void returnvalue( int i );

    public returnvalue ReturnValue;

    form2 中的button按钮代码如下:

    private void button1_Click(object sender, System.EventArgs e)

    {

        if ( ReturnValue != null )

            ReturnValue( 8 );

    }

     

    Form1中的button按键如下:

    private void button1_Click(object sender, System.EventArgs e)

    {

        Form2 temp = new Form2( );

        temp.ReturnValue = new temp.Form2.returnvalue( showvalue );

        temp.Show();

    }

     

    private void showvalue( int i )

    {

        textBox1.Text = i.ToString();

    }

     

    点击form2的button,form1中的textbox中的值就会相应变化。

     

    在这四个方法中,

    第一个是双向传值,也就是说,form1和form2改变i的值,另一方也会受到影响。

    第二个方法可以单向也可以双向传值。

    第三个方法是form1->form2单向传值。

    第四个方法是form2->form1单向传值。

     

    以后有新的方法我再补充,还有一个就是用event,和delegate差不多,在这里就不说了。

     

    转自:http://blog.csdn.net/tjvictor/article/details/824617

  • 相关阅读:
    八月最后的一天
    Go语言系列一
    一个工具libre draw
    Linux启动eclipse报错找不到java环境解决方法
    P2P通讯初步实现
    C#中,当鼠标移动到控件上,动态显示提示内容 ToolTip
    在windows64位的系统上面操作操作excel程序出现异常
    office2007下载地址
    蜗牛算法
    利用vs自带工具分析程序性能
  • 原文地址:https://www.cnblogs.com/xiurui12345/p/2442801.html
Copyright © 2011-2022 走看看