• 在.net应用程序中使用用户控件.NET教程,组件控件开发(转载)


    在.net应用程序中使用用户控件
    做过asp.net的人都知道开发的时候使用用户控件很方便,为功能模块化提供了相当大的灵活性。令人高兴的是开发windows窗体也可以使用用户控件。这里我们来看看为用户控件添加属性和事件,并实现把消息发送到父容器。本文主要是为没有使用过用户控件的朋友提供一些参考。

    用户控件的实现比较简单,直接从system.windows.forms.usercontrol。

    public class usercontrol1 : system.windows.forms.usercontrol



    为了便于测试我在上面添加了一个textbox,并注册textbox的textchanged事件,

    this.textbox1.textchanged += new system.eventhandler(this.textbox1_textchanged);

    事件处理函数,

    private void textbox1_textchanged(object sender, system.eventargs e)

    {

    messagebox.show(this.textbox1.text);

    }

    这里演示如果控件中文本框的内容改变就会用messagebox显示当前的文本框内容。

    控件显示如下:



    在窗体中添加上面的用户控件,当我们改变textbox的文本时,可以看到跳出一个对话框,很简单吧。

    下面来看看对控件添加属性。

    这里定义一个私有变量。

    private string customvalue;

    添加访问他的属性

    public string customvalue

    {

    get{return customvalue;}

    set{customvalue =value;}

    }

    在窗体中使用的时候像普通控件一样进行访问,

    usercontrol11.customvalue = "用户控件自定义数据";

    通过事件可以传递消息到窗体上,在定义之前我们先来写一个简单的参数类。

    public class textchangeeventargs : eventargs

    {

    private string message;

    public textchangeeventargs(string message)

    {

    this.message = message;

    }

    public string message

    {

    get{return message;}

    }

    }

    定义委托为,

    public delegate void textboxchangedhandle(object sender,textchangeeventargs e);

    接下去在用户控件中添加事件,

    //定义事件

    public event textboxchangedhandle usercontrolvaluechanged;

    为了激发用户控件的新增事件,修改了一下代码,

    private void textbox1_textchanged(object sender, system.eventargs e)

    {

    if(usercontrolvaluechanged != null)

    usercontrolvaluechanged(this,new textchangeeventargs(this.textbox1.text));



    }

    好了,为了便于在csdn上回答问题,把完整的代码贴了出来:

    using system;

    using system.collections;

    using system.componentmodel;

    using system.drawing;

    using system.data;

    using system.windows.forms;



    namespace zz.windowsapplication1

    {

    public class usercontrol1 : system.windows.forms.usercontrol

    {

    private system.windows.forms.textbox textbox1;

    private string customvalue;



    private system.componentmodel.container components = null;



    public string customvalue

    {

    get{return customvalue;}

    set{customvalue =value;}

    }



    //定义事件

    public event textboxchangedhandle usercontrolvaluechanged;



    public usercontrol1()

    {

    initializecomponent();

    }



    protected override void dispose( bool disposing )

    {

    if( disposing )

    {

    if(components != null)

    {

    components.dispose();

    }

    }

    base.dispose( disposing );

    }



    #region 组件设计器生成的代码

    private void initializecomponent()

    {

    this.textbox1 = new system.windows.forms.textbox();

    this.suspendlayout();

    this.textbox1.location = new system.drawing.point(12, 36);

    this.textbox1.name = "textbox1";

    this.textbox1.tabindex = 0;

    this.textbox1.text = "textbox1";

    this.textbox1.textchanged += new system.eventhandler(this.textbox1_textchanged);

    this.controls.add(this.textbox1);

    this.name = "usercontrol1";

    this.size = new system.drawing.size(150, 92);

    this.resumelayout(false);



    }

    #endregion



    private void textbox1_textchanged(object sender, system.eventargs e)

    {

    if(usercontrolvaluechanged != null)

    usercontrolvaluechanged(this,new textchangeeventargs(this.textbox1.text));



    }

    }

    //定义委托

    public delegate void textboxchangedhandle(object sender,textchangeeventargs e);



    public class textchangeeventargs : eventargs

    {

    private string message;

    public textchangeeventargs(string message)

    {

    this.message = message;

    }

    public string message

    {

    get{return message;}

    }

    }

    }

    使用时要在窗体中注册上面的事件,比较简单都贴源代码了,

    using system;

    using system.drawing;

    using system.collections;

    using system.componentmodel;

    using system.windows.forms;

    using system.data;



    namespace zz.windowsapplication1

    {

    public class form1 : system.windows.forms.form

    {

    private windowsapplication1.usercontrol1 usercontrol11;

    private system.componentmodel.container components = null;



    public form1()

    {

    initializecomponent();

    usercontrol11.customvalue = "用户控件自定义数据";

    usercontrol11.usercontrolvaluechanged += new textboxchangedhandle(usercontrol11_usercontrolvaluechanged);

    }



    protected override void dispose( bool disposing )

    {

    if( disposing )

    {

    if (components != null)

    {

    components.dispose();

    }

    }

    base.dispose( disposing );

    }



    #region windows 窗体设计器生成的代码

    private void initializecomponent()

    {

    this.usercontrol11 = new windowsapplication1.usercontrol1();

    this.suspendlayout();

    this.usercontrol11.location = new system.drawing.point(8, 8);

    this.usercontrol11.name = "usercontrol11";

    this.usercontrol11.size = new system.drawing.size(150, 84);

    this.usercontrol11.tabindex = 0;

    this.autoscalebasesize = new system.drawing.size(6, 14);

    this.clientsize = new system.drawing.size(292, 193);

    this.controls.add(this.usercontrol11);

    this.name = "form1";

    this.text = "form1";

    this.resumelayout(false);



    }

    #endregion



    [stathread]

    static void main()

    {

    application.run(new form1());

    }



    private void usercontrol11_usercontrolvaluechanged(object sender, textchangeeventargs e)

    {

    messagebox.show("当前控件的值为:" + e.message);

    }

    }

    }

    另外需要动态加载,就把控件添加在容器的controls集合就行了,下面是在构造函数中添加控件,

    public form1()

    {

    initializecomponent();

    usercontrol1 uc = new usercontrol1();

    uc.customvalue = "动态加载的用户控件";

    uc.usercontrolvaluechanged += new textboxchangedhandle(usercontrol11_usercontrolvaluechanged);

    this.controls.add(uc);

    }

    另外从vs.net中的工具箱中拖动用户控件到窗体上,如果是第一次需要编译一下项目。



    文章整理:西部数码--专业提供域名注册虚拟主机服务
    http://www.west263.com
    以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

  • 相关阅读:
    idhttp post 上传或下载时显示进度条(对接idhttp1.OnWork事件)
    DBGridEh列宽自动适应内容的简单方法
    好的python链接
    Git安装和使用
    Git及码云学习总结
    创建编写博客园写博客
    Git和Github的使用
    sql sever 两数据表差异比较EXCEPT、INTERSECT
    Vue学习(七)capture模式
    Vue学习(六)计算属性和侦听属性的区别以及应用场景
  • 原文地址:https://www.cnblogs.com/chorrysky/p/829726.html
Copyright © 2020-2023  润新知