Доступ к дочерним элементам управления в шаблонном пользовательском элементе управления ASP.NET - PullRequest
6 голосов
/ 01 августа 2011

Следующие коды упрощены.

Пользовательский контроль ascx:

<%@ Control Language="C#" AutoEventWireup="true" CodeBehind="BaseFormControl.ascx.cs"
    Inherits="SOPR.CustomForms.BaseFormControl" %>
<fieldset class="fset1">
</fieldset>

Это мой код контроля пользователя:

public partial class BaseFormControl : System.Web.UI.UserControl
    {



        [TemplateContainer(typeof(ContentContainer))]
        [PersistenceMode(PersistenceMode.InnerProperty)]
        public ITemplate Content { get; set; }



   void Page_Init()
        {




            if (Content != null)
            {
                ContentContainer cc = new ContentContainer();
                Content.InstantiateIn(cc);
                contentHolder.Controls.Add(cc);
            }
        }

Мое использование в представлении:

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="AddOperator.aspx.cs"
    Inherits="SOPR.Cadastro.AddOperator" MasterPageFile="~/MasterPage.Master" %>

<asp:Content ContentPlaceHolderID="ContentPlaceHolder1" ID="maincont" runat="server"     EnableViewState="true">
    <uc:BaseFormControl ID="BaseFormControl1" runat="server">
        <Content>
      <asp:TextBox runat="server" CssClass="keytbcss" MaxLength="4" ID="keytb"
                NewLine="false" />
        </Content>
    </uc:BaseFormControl>

Я пытаюсь получить доступ к элементу управления «keytb» в коде, но его как будто и не существует (как, например, использование переменной, которой не существует) Есть идеи?

Заранее спасибо.

РЕШЕНИЕ --------------------------
Я нашел довольно хорошее решение, просто добавьте [TemplateInstance (TemplateInstance.Single)] к свойству ITemplate пользовательского элемента управления, и все будет видно. Теперь я могу использовать, как будто это был обычный элемент управления страницей.

public partial class BaseFormControl : System.Web.UI.UserControl
{



[TemplateContainer(typeof(ContentContainer))]
[PersistenceMode(PersistenceMode.InnerProperty)]
[TemplateInstance(TemplateInstance.Single)]
public ITemplate Content { get; set; }
...

Ответы [ 3 ]

5 голосов
/ 02 августа 2011

РЕШЕНИЕ --------------------------
Я нашел довольно хорошее решение, просто добавьте [TemplateInstance (TemplateInstance.Single)]к свойству ITemplate пользовательского элемента управления, и все становится видимым.Теперь я могу использовать как обычный элемент управления страницы.

public partial class BaseFormControl : System.Web.UI.UserControl
{



[TemplateContainer(typeof(ContentContainer))]
[PersistenceMode(PersistenceMode.InnerProperty)]
[TemplateInstance(TemplateInstance.Single)]
public ITemplate Content { get; set; }
...
0 голосов
/ 01 августа 2011

Когда вы пишете элемент управления внутри шаблона, вы даете ему пример того, каким будет содержимое.Представьте, что вы даете содержимое сетки в шаблоне с некоторым идентификатором «SomeTextBox», SomeTextBox не может появляться несколько раз, когда увеличивается число строк в сетке.Элемент управления будет называть его динамически во время выполнения.

Но все же у вас есть способ, вам нужно найти контейнерный элемент управления и применить к нему метод Control.FindControl ().FindControl () принимает идентификатор элемента вашего шаблона, который вы указали во время разработки.

0 голосов
/ 01 августа 2011

Я бы сделал метод для доступа к элементам управления контентом в вашем пользовательском элементе управления:

public Control FindInnerControl  (string id)
{
  if (contentHolder.Controls.Count > 0)
  {
    return contentHolder.Controls [0].FindControl (id); //The first control is your ContentContainer
  }
  return null;
}

тогда в коде вашей страницы вы можете сделать

TextBox txtKeytbcss = (TextBox) BaseFormControl1.FindInnerControl ("keytbcss");
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...