IBindingList.Find(PropertyDescriptor, Object) Método

Definição

Retorna o índice da linha que tem o determinado PropertyDescriptor.

public:
 int Find(System::ComponentModel::PropertyDescriptor ^ property, System::Object ^ key);
public int Find(System.ComponentModel.PropertyDescriptor property, object key);
abstract member Find : System.ComponentModel.PropertyDescriptor * obj -> int
Public Function Find (property As PropertyDescriptor, key As Object) As Integer

Parâmetros

property
PropertyDescriptor

O PropertyDescriptor para pesquisar.

key
Object

O valor do parâmetro a property ser pesquisado.

Retornos

O índice da linha que tem o determinado PropertyDescriptor.

Exceções

Exemplos

O exemplo de código a seguir demonstra como implementar o Find método.

public class MyFontList : BindingList<Font>
{
    protected override bool SupportsSearchingCore => true;
    protected override int FindCore(PropertyDescriptor prop, object key)
    {
        // Ignore the prop value and search by family name.
        for (int i = 0; i < Count; ++i)
        {
            if (Items[i].FontFamily.Name.Equals((string)key, StringComparison.CurrentCultureIgnoreCase))
            {
                return i;
            }
        }
        return -1;
    }
}
Public Class MyFontList
    Inherits BindingList(Of Font)

    Protected Overrides ReadOnly Property SupportsSearchingCore() As Boolean
        Get
            Return True
        End Get
    End Property
    
    Protected Overrides Function FindCore(ByVal prop As PropertyDescriptor, _
        ByVal key As Object) As Integer
        ' Ignore the prop value and search by family name.
        Dim i As Integer
        While i < Count
            If Items(i).FontFamily.Name.ToLower() = CStr(key).ToLower() Then
                Return i
            End If
            i += 1
        End While

        Return -1
    End Function
End Class

Comentários

Esse método selecionará a primeira linha em que o valor do property parâmetro é igual ao valor do key parâmetro.

Esse método terá suporte se SupportsSearching for true, caso contrário, esse método gerará um NotSupportedException.

Aplica-se a