• ASP.NET 用户控件的创建和使用


    用户控件就是代码的重用性的体现。

    一个用户控件就是一个简单的ASP.NET页面,不过他是包含在另一个ASP.NET页面的,用户控件文件有如下特点:

    1.扩展名为:.ascx。

    2.用户控件中没有“@ page”指令,而是包含“@ Control”指令,该指令对配置及其他的属性进行定义。

    3.用户控件不能作为独立文件运行,而是必须像处理控件一样,将它们添加到Asp.net页中。

    4.用户控件中没有html,body,或form元素,这些元素不许位于宿主中。

    如下:

    Code

    创建一个搜索数据的用户控件:

    1.添加一个Sample.ascx的文件

    2.从工具箱中拖入1个Lable控件,设置ID为:ColumnName

    3.从工具箱中拖入1个TextBox控件,设置其属性ID为:Condition,

    4.从工具箱里拖入一个Button控件,并设置其属性ID为:Search,Text为搜索。

    看“源”文件如下:

    Code

    5,打开Search.ascx.cn文件看后置代码,定义如下属性

    Code

    6.定义一个函数,SearchResult(),该函数将会根据用户输入的查询条件查询到数据并把数据集返回,该函数要利用到数据库访问知识,代码如下:

     

    Code

    7.打开Search.ascx文件,双击Search按钮,则在Search.ascx.cs文件中生成按钮事件,这个事件中将绑定数据到GridView中。

    1   protected void Search_Click(object sender, EventArgs e)
    2         {
    3             resultGridView.DataSource = SearchResult().DefaultView;
    4             resultGridView.DataBind();
    5         }
    6 

     8.在Page_Load事件中加入初始化ColumnName标签代码,

           protected void Page_Load(object sender, EventArgs e)
            
    {
                
    this.ColumnName.Text = this.lableText;
            }

    这样就创建好了一个搜索功能的用户控件,这个控件在哪个页面需要使用时,只需要加入到ASP.ENT页面就行了,像使用WEB控件一样。

    用户控件的使用:

    使用用户控件和使用web控件一样,拖入页面,然后设置他的属性就是了。

    就拿刚才的搜索功能的用户控件来说,

    1.在Default.aspx页面拖入用户控件

    如下代码,我们在页面添加了一个ID为Sample1的用户控件和一个ID为:GridView1的GridView,并绑定数据。

    Code

    设置页面加载事件

    因为页面已经添加了控件,所以后台代码就可以设置控件的属性的值了,

    Sample1.connectionString 设置连接字符串,

    Sample1.columnCondition 设置按哪个字段查询

    Sample1.tableName = "basic" 设置查询哪个表,

    Sample1.resultGridView = this.GridView1。设置控件的GridView

    Code

    因为我们在控件的按钮事件中有如下代码,所以,当点击搜索,就会绑定数据到GridView

     protected void Search_Click(object sender, EventArgs e)
            {
                resultGridView.DataSource = SearchResult().DefaultView;
                resultGridView.DataBind();
            }

    分析用户控件的创建和使用:

    <%@ Register src="UC/Sample.ascx" tagname="Sample" tagprefix="uc1" %>

      <uc1:Sample ID="Sample1" runat="server" lableText="城市:"/>

    ···走了,下班了。

  • 相关阅读:
    链表的相关操作
    【回溯】旅行商问题
    【回溯】图的m着色问题
    奶牛卧室_待解决
    阶乘问题
    子数整数
    hihoCoder week4 Trie图
    hihoCoder week3 KMP算法
    hihoCoder week2 Trie树
    hihoCoder week1 最长回文子串
  • 原文地址:https://www.cnblogs.com/bayker/p/1607041.html
Copyright © 2020-2023  润新知