ITypedList Interface
Definição
Importante
Algumas informações dizem respeito a um produto pré-lançado que pode ser substancialmente modificado antes de ser lançado. A Microsoft não faz garantias, de forma expressa ou implícita, em relação à informação aqui apresentada.
Fornece funcionalidade para descobrir o esquema para uma lista vinculável, onde as propriedades disponíveis para ligação diferem das propriedades públicas do objeto a ligar.
public interface class ITypedList
public interface ITypedList
type ITypedList = interface
Public Interface ITypedList
- Derivado
Exemplos
O exemplo de código a seguir demonstra como implementar o ITypedList interface. Um tipo genérico nomeado SortableBindingList deriva da BindingList<T> classe e implementa a ITypedList interface. Para uma lista completa de código, veja Como: Implementar a Interface ITypedList.
using System;
using System.ComponentModel;
using System.Windows.Forms;
namespace ITypedListCS;
[Serializable()]
public class SortableBindingList<T> : BindingList<T>, ITypedList
{
[NonSerialized()]
readonly PropertyDescriptorCollection properties;
public SortableBindingList() : base()
{
// Get the 'shape' of the list.
// Only get the public properties marked with Browsable = true.
PropertyDescriptorCollection pdc = TypeDescriptor.GetProperties(
typeof(T),
[new BrowsableAttribute(true)]);
// Sort the properties.
properties = pdc.Sort();
}
#region ITypedList Implementation
public PropertyDescriptorCollection GetItemProperties(PropertyDescriptor[] listAccessors)
{
PropertyDescriptorCollection pdc;
if (listAccessors != null && listAccessors.Length > 0)
{
// Return child list shape.
pdc = ListBindingHelper.GetListItemProperties(listAccessors[0].PropertyType);
}
else
{
// Return properties in sort order.
pdc = properties;
}
return pdc;
}
// This method is only used in the design-time framework
// and by the obsolete DataGrid control.
public string GetListName(PropertyDescriptor[] listAccessors) => typeof(T).Name;
#endregion
}
Imports System.ComponentModel
Imports System.Collections.Generic
Imports System.Windows.Forms
<Serializable()> _
Public Class SortableBindingList(Of Tkey)
Inherits BindingList(Of Tkey)
Implements ITypedList
<NonSerialized()> _
Private properties As PropertyDescriptorCollection
Public Sub New()
MyBase.New()
' Get the 'shape' of the list.
' Only get the public properties marked with Browsable = true.
Dim pdc As PropertyDescriptorCollection = TypeDescriptor.GetProperties(GetType(Tkey), New Attribute() {New BrowsableAttribute(True)})
' Sort the properties.
properties = pdc.Sort()
End Sub
#Region "ITypedList Implementation"
Public Function GetItemProperties(ByVal listAccessors() As System.ComponentModel.PropertyDescriptor) As System.ComponentModel.PropertyDescriptorCollection Implements System.ComponentModel.ITypedList.GetItemProperties
Dim pdc As PropertyDescriptorCollection
If (Not (listAccessors Is Nothing)) And (listAccessors.Length > 0) Then
' Return child list shape
pdc = ListBindingHelper.GetListItemProperties(listAccessors(0).PropertyType)
Else
' Return properties in sort order
pdc = properties
End If
Return pdc
End Function
' This method is only used in the design-time framework
' and by the obsolete DataGrid control.
Public Function GetListName( _
ByVal listAccessors() As PropertyDescriptor) As String _
Implements System.ComponentModel.ITypedList.GetListName
Return GetType(Tkey).Name
End Function
#End Region
End Class
Observações
Use esta interface se, por exemplo, estiver a usar um DataView objeto que representa uma customer tabela, quiser ligar às propriedades do customer objeto que o DataView representa, não às propriedades do DataView.
Esta interface não é necessária para suporte em tempo de design de uma lista vinculável.
A ligação a dados pode ocorrer tanto em tempo de execução como num designer, mas existem regras para ambos. Em tempo de execução, pode vincular dados em qualquer uma das seguintes opções:
Implementador de IList, desde que o implementador tenha uma propriedade fortemente tipada Item[] (ou seja, o Type é qualquer coisa menos Object). Pode conseguir isto tornando a implementação padrão de Item[] privada. Se quiser criar um IList que siga as regras de uma coleção fortemente tipada, deve derivar de CollectionBase.
Implementador de ITypedList.
Num designer, podes inicializar a ligação a Component objetos seguindo as mesmas regras.
Para mais informações sobre ligação a uma fonte de dados, consulte a classe System.Windows.Forms.Binding.
Métodos
| Name | Description |
|---|---|
| GetItemProperties(PropertyDescriptor[]) |
Devolve o PropertyDescriptorCollection que representa as propriedades de cada item usado para ligar dados. |
| GetListName(PropertyDescriptor[]) |
Devolve o nome da lista. |