天天看点

在用户控件(ASCX)创建用户控件(ASCX)

"我建了两个ascx,ascxA,ascxB

ascxA中放了一个PlaceHold,

ascxB中放了一个textBox

ascxA在page_load中动态创建了5个ascxB但是页面上什么都没显示"

这是来自论坛网友的问题,Insus.NET就以此问题做一个演示例子,方法与技巧分享给大家。

 在站点上创建一个用户控件ascx B, 拉一个TextBox在这个控件上。

创建另一个用户控件ascx A 在这个用户控件上,拉一个Textbox 和一个按钮,是让用户在文本框输入数据,点一点铵钮,这样动态产生ascx B用户控件,呈现于ascx A用户控件的页面上。

在站点上,创建一个aspx网页。把用户控件ascx 引用至aspx网页上。再在aspx网页上拉一个按钮。让用户点一点这个铵钮,去获取动态产生的文本框的值,并显示于aspx网页上。

现在的问题,ascx A动态加载ascx B. 根据用户输入的数字来产生。

怎样在aspx网页上,去获取那些动态产生文本框的值?

好,带着疑问一步一步来完成它们。

创建一个站点,Insus.NET使用的是.NET 4.0 和C#作为程序语言。

创建一个AscxB.ascx用户控件:

在用户控件(ASCX)创建用户控件(ASCX)
在用户控件(ASCX)创建用户控件(ASCX)

<%@ Control Language="C#" AutoEventWireup="true" CodeFile="AscxB.ascx.cs" Inherits="AscxB" %>
<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>      

View Code

AscxB.ascx.cs:

在用户控件(ASCX)创建用户控件(ASCX)
在用户控件(ASCX)创建用户控件(ASCX)
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

public partial class AscxB : System.Web.UI.UserControl
{
    protected void Page_Load(object sender, EventArgs e)
    {

    }       
}      

 在站点上创建用户控件AscxA.asx,在此控件上,拉一个文本框TextBox,一个铵钮Button和一个容器PlaceHolder。在铵钮添加onclick事件OnClick="ButtonGenerate_Click"

在用户控件(ASCX)创建用户控件(ASCX)
在用户控件(ASCX)创建用户控件(ASCX)
<%@ Control Language="C#" AutoEventWireup="true" CodeFile="AscxA.ascx.cs" Inherits="AscxA" %>
<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>&nbsp;&nbsp;<asp:Button ID="ButtonGenerate" runat="server" Text="Generate" OnClick="ButtonGenerate_Click" /><br />
<br />
<asp:PlaceHolder ID="PlaceHolder1" runat="server"></asp:PlaceHolder>      

AscxA.ascx.cs:

在用户控件(ASCX)创建用户控件(ASCX)
在用户控件(ASCX)创建用户控件(ASCX)
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

public partial class AscxA : System.Web.UI.UserControl
{  
    protected void Page_Load(object sender, EventArgs e)
    {
      
    }

    protected void ButtonGenerate_Click(object sender, EventArgs e)
    {
       
    }   
}      

下面是动态加载用户控件的方法,为了能让用户控件ascx a加载到ascx b。 Insus.NET在此,先创建接口(interface):

​​

在用户控件(ASCX)创建用户控件(ASCX)

接口写好,去ascx B实作这个接口:

在用户控件(ASCX)创建用户控件(ASCX)

我们回到用户控件ascxA cs代码页,去写按钮Click的事件:

 ​​

在用户控件(ASCX)创建用户控件(ASCX)

上图中的29行代码,是判断文件框是否为空,是不是为数字。

第35代码,是动态加载用户控件ascx B之后,并转为接口IUserControlable。然后加入PlaceHolder容器中去。

现在,我们创建一个网页.aspx,在此网页中,我们引用用户控件ascxa,还在拉一个铵钮,和个Literal控件,铵钮与Literal最开始状态是隐藏的,主要是用来获取数据与显示数据。

在用户控件(ASCX)创建用户控件(ASCX)

.aspx.cs代码:

在用户控件(ASCX)创建用户控件(ASCX)
在用户控件(ASCX)创建用户控件(ASCX)
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;


public partial class DynamicallyLoadUserControlDemo : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        
    }

    protected void ButtonGetValue_Click(object sender, EventArgs e)
    {        

    }   
}      

现在,我们做一些其它,即是说,在Ascx A用户控件,当有动态产生Ascx B控件之后,在网页的Button才会显示。如果没有产生过铵钮,网页Button就是隐藏起来。

由于是否有控件产生是发生在ascx A用户控件,而隐藏的对象在网页上。这涉及到用户控件与网页之间的沟通与协调。

为了减低程序的复杂度,Insus.NET得写一个接口,这个接口主体只有一个只写属性。

在用户控件(ASCX)创建用户控件(ASCX)

接口写好了,我们在网页.aspx.cs实作这个接口。说明白一点,就是网页的铵钮只接受显示与隐藏,是谁来决定显示与隐藏,它管不了。

在用户控件(ASCX)创建用户控件(ASCX)

具体是谁来控制显示与隐藏呢,刚才所说,是在用户控件ascx A的动态产生ascx B之后,这个网页的Button就显示。因此,我们去用户控件ascx a的产生控件代码中添加:

在用户控件(ASCX)创建用户控件(ASCX)

有点疑问,怎样能把网页转为接口呢? 因为我们上面有把网页实作了IShowable这个接口。

Ok, 我们回到网页cs,准备写铵钮click事件,来获取数据。不过获取数据起来,是有点困难,因为动态产生的控件,全是在用户控件ascx A中呈现,而且每呈现的文本框是来自ascx B。

在网页中,怎样获取俄用户控件的ascx A的容器PlaceHolder呢? Insus.NET只会使用接口,因此还是写另外一个接口,是为了让网页.aspx.cs去读取用户控件的Ascx A的PlaceHolder。

在用户控件(ASCX)创建用户控件(ASCX)

我们去用户控件ascx A实用这个接口:

在用户控件(ASCX)创建用户控件(ASCX)

这样子,我们就可以在网页.aspx.cs的获取值的铵钮获取这个容器了。另外,由于容器根据用户的需求,也许不止单一次产生一个ascx B用户控件,也许会有好几个。我们怎样知道哪一个文本框TextBox是哪一个TextBox呢?

还是写一个接口吧,

在用户控件(ASCX)创建用户控件(ASCX)

接口写好,我们去ascx B用户控件来实作这个接口:

在用户控件(ASCX)创建用户控件(ASCX)

到现在为止,我们完全可以去网页代码中,去写铵钮的Click获取值的事件了:

在用户控件(ASCX)创建用户控件(ASCX)

上面代码中,#0是获取placeholder容器。

#1是foreach容器中所有文本框。

#2是显示文本框的值。

到此为止,算是演示完成了。不过,我们还是来一个最终的效果演示吧:

在用户控件(ASCX)创建用户控件(ASCX)

Demo source code:

继续阅读