Прочитать на английском

Поделиться через


ParseChildrenAttribute Класс

Определение

Определяет атрибут метаданных, используемый при разработке серверного элемента управления ASP.NET. Класс ParseChildrenAttribute позволяет указать, как анализатор страницы должен интерпретировать содержимое тэга серверного элемента управления, объявленного на странице. Этот класс не наследуется.

[System.AttributeUsage(System.AttributeTargets.Class)]
public sealed class ParseChildrenAttribute : Attribute
Наследование
ParseChildrenAttribute
Атрибуты

Примеры

Пример кода в этом разделе содержит две части. В первом примере кода показано, как задать свойства для ParseChildrenAttribute класса . Во втором примере кода показано, как использовать классы на странице ASP.NET.

В следующем примере кода показано, как задать ParseChildrenAttribute объект пользовательского серверного элемента управления с именем CollectionPropertyControl. Задает ParseChildrenAttribute свойству ChildrenAsProperties значение , true а свойству DefaultPropertyEmployee — класс .

using System;
using System.Collections;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Security.Permissions;

namespace Samples.AspNet.CS.Controls
{
   // The child element class.
   [AspNetHostingPermission(SecurityAction.Demand, 
      Level=AspNetHostingPermissionLevel.Minimal)]
   public sealed class Employee
   {
      private String name;
      private String title;
      private String alias;

      public Employee():this ("","",""){}
      
      public Employee (String name, String title, String alias)
      {
         this.name = name;
         this.title = title;
         this.alias = alias;
      }
      public String Name
      {
         get
         {
            return name;
         }
         set
         {
            name = value;
         }
      }
      
      public String Title
      {
         get
         {
            return title;
         }
         set
         {
            title = value;
         }
      }
      
      public String Alias
      {
         get
         {
            return alias;
         }
         set
         {
            alias = value;
         }
      }
   }
   // Use the ParseChildren attribute to set the ChildrenAsProperties
   // and DefaultProperty properties. Using this constructor, the
   // control parses all child controls as properties and must define
   // a public property named Employees, which it declares as
   // an ArrayList. Nested (child) elements must correspond to
   // child elements of the Employees property or to other
   // properties of the control.  
   [ParseChildren(true, "Employees")]
   [AspNetHostingPermission(SecurityAction.Demand, 
      Level=AspNetHostingPermissionLevel.Minimal)]
   public sealed class CollectionPropertyControl : Control
   {  
      private String header;
      private ArrayList employees = new ArrayList();
      
      public String Header
      {
         get
         {
            return header;
         }
         set
         {
            header = value;
         }
      }

      public ArrayList Employees
      {
         get 
         {
            return employees;
         }
      }
      // Override the CreateChildControls method to 
      // add child controls to the Employees property when this
      // custom control is requested from a page.
      protected override void CreateChildControls()
      {
         Label label = new Label();
         label.Text = Header;
         label.BackColor = System.Drawing.Color.Beige;
         label.ForeColor = System.Drawing.Color.Red;
         Controls.Add(label);
         Controls.Add(new LiteralControl("<BR> <BR>"));

         Table table = new Table();
         TableRow htr = new TableRow();

         TableHeaderCell hcell1 = new TableHeaderCell();    
         hcell1.Text = "Name";
         htr.Cells.Add(hcell1);

         TableHeaderCell hcell2 = new TableHeaderCell();
         hcell2.Text = "Title";
         htr.Cells.Add(hcell2);
         
         TableHeaderCell hcell3 = new TableHeaderCell();
         hcell3.Text = "Alias";
         htr.Cells.Add(hcell3);
         table.Rows.Add(htr);

         table.BorderWidth = 2;
         table.BackColor = System.Drawing.Color.Beige;
         table.ForeColor = System.Drawing.Color.Red;
         foreach (Employee employee in Employees)
         {
            TableRow tr = new TableRow();

            TableCell cell1 = new TableCell();
            cell1.Text = employee.Name;
            tr.Cells.Add(cell1);
            
            TableCell cell2 = new TableCell();
            cell2.Text = employee.Title;
            tr.Cells.Add(cell2);
            
            TableCell cell3 = new TableCell();
            cell3.Text = employee.Alias;
            tr.Cells.Add(cell3);
            
            table.Rows.Add(tr);
         }
         Controls.Add(table);
      }
   }
}

В следующем примере кода показано, как использовать классы CollectionPropertyControl и Employee на странице ASP.NET. Экземпляры Employee класса добавляются декларативно.

<%@ Page Language="C#" Debug="true" %>
<%@ Register TagPrefix="AspSample" Assembly="Samples.AspNet.CS.Controls" Namespace="Samples.AspNet.CS.Controls" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<script runat="server">

  protected void Page_Load(object sender, EventArgs e)
  {
    
    // Verify attribute values.
    ParseChildrenAttribute p = 
      (ParseChildrenAttribute)Attribute.GetCustomAttribute(typeof(CollectionPropertyControl),
      typeof(ParseChildrenAttribute));

    StringBuilder sb = new StringBuilder();
    sb.Append("The DefaultProperty property is " + p.DefaultProperty.ToString() + "<br />");
    sb.Append("The ChildrenAsProperties property is " + p.ChildrenAsProperties.ToString() + "<br />");
    sb.Append("The IsDefaultAttribute method returns " + p.IsDefaultAttribute().ToString());
    Message.Text = sb.ToString();

  }
</script>

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title>ParseChildrenAttribute Example</title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
      <asp:Label ID="Message"
                 runat="server"/>
      <AspSample:CollectionPropertyControl id="CollectionPropertyControl1" 
                                           runat="server">
        <AspSample:Employee Name="Employee 1" 
                            Title="Title 1" 
                            Alias="Alias 1" />
        <AspSample:Employee Name="Employee 2" 
                            Title="Title 2" 
                            Alias="Alias 2" />
      </AspSample:CollectionPropertyControl>    
    </div>
    </form>
</body>
</html>

Комментарии

Класс ParseChildrenAttribute позволяет указать логику синтаксического анализа для пользовательского серверного элемента управления, помечая серверный элемент управления атрибутом ParseChildrenAttribute метаданных.

Помечая серверный элемент управления атрибутом ParseChildren(true) метаданных, средство синтаксического анализа интерпретирует элементы, содержащиеся в тегах серверного элемента управления, как свойства. В этом сценарии ChildrenAsProperties свойство имеет значение true.

Пометка серверного элемента управления атрибутом ParseChildren(true,"<Default Property>") метаданных задает DefaultProperty для свойства имя свойства, передаваемого в атрибут .

Помечая серверный элемент управления атрибутом ParseChildren(false)метаданных , значением по умолчанию, средство синтаксического анализа интерпретирует элементы, содержащиеся в тегах серверного элемента управления, как содержимое, которое будет проанализировано со связанным ControlBuilder , то есть как элементы управления. В этом сценарии ChildrenAsProperties свойство имеет значение false.

Сведения об использовании атрибутов см. в разделе Атрибуты.

Конструкторы

ParseChildrenAttribute()

Инициализирует новый экземпляр класса ParseChildrenAttribute.

ParseChildrenAttribute(Boolean)

Инициализирует новый экземпляр класса ParseChildrenAttribute, используя свойство ChildrenAsProperties, чтобы определить, анализируются ли элементы, находящиеся в серверном элементе управления, как свойства серверного элемента управления.

ParseChildrenAttribute(Boolean, String)

Инициализирует новый экземпляр класса ParseChildrenAttribute, используя параметры childrenAsProperties и defaultProperty.

ParseChildrenAttribute(Type)

Инициализирует новый экземпляр класса ParseChildrenAttribute, используя свойство ChildControlType, чтобы определить, какие элементы, находящиеся в серверном элементе управления, анализируются как элементы управления.

Поля

Default

Определяет значение по умолчанию для класса ParseChildrenAttribute. Это поле доступно только для чтения.

ParseAsChildren

Указывает, что вложенное содержимое, находящееся в серверном элементе управления, не анализируется как серверные элементы управления.

ParseAsProperties

Указывает, что вложенное содержимое, находящееся в серверном элементе управления, анализируется как свойства серверного элемента управления.

Свойства

ChildControlType

Возвращает значение, указывающее допустимый тип элемента управления.

ChildrenAsProperties

Возвращает или задает значение, определяющее, анализируются ли элементы, содержащиеся в серверном элементе управления, как свойства.

DefaultProperty

Возвращает или задает свойство по умолчанию для серверного элемента управления, в котором анализируются элементы.

TypeId

В случае реализации в производном классе возвращает уникальный идентификатор для этого атрибута Attribute.

(Унаследовано от Attribute)

Методы

Equals(Object)

Определяет, равен ли указанный объект текущему объекту.

GetHashCode()

Служит в качестве хэш-функции для объекта ParseChildrenAttribute.

GetType()

Возвращает объект Type для текущего экземпляра.

(Унаследовано от Object)
IsDefaultAttribute()

Возвращает значение, указывающее является ли значение текущего экземпляра класса ParseChildrenAttribute значением по умолчанию производного класса.

Match(Object)

При переопределении в производном классе возвращает значение, указывающее, является ли этот экземпляр равным заданному объекту.

(Унаследовано от Attribute)
MemberwiseClone()

Создает неполную копию текущего объекта Object.

(Унаследовано от Object)
ToString()

Возвращает строку, представляющую текущий объект.

(Унаследовано от Object)

Явные реализации интерфейса

_Attribute.GetIDsOfNames(Guid, IntPtr, UInt32, UInt32, IntPtr)

Сопоставляет набор имен соответствующему набору идентификаторов диспетчеризации.

(Унаследовано от Attribute)
_Attribute.GetTypeInfo(UInt32, UInt32, IntPtr)

Возвращает сведения о типе объекта, которые можно использовать для получения сведений о типе интерфейса.

(Унаследовано от Attribute)
_Attribute.GetTypeInfoCount(UInt32)

Возвращает количество предоставляемых объектом интерфейсов для доступа к сведениям о типе (0 или 1).

(Унаследовано от Attribute)
_Attribute.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr)

Предоставляет доступ к открытым свойствам и методам объекта.

(Унаследовано от Attribute)

Применяется к

Продукт Версии
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1

См. также раздел