ListView.DataKeys Propriedade

Definição

Obtém uma coleção de DataKey objetos que representam o valor da chave de dados para cada item num ListView controlo.

public:
 virtual property System::Web::UI::WebControls::DataKeyArray ^ DataKeys { System::Web::UI::WebControls::DataKeyArray ^ get(); };
[System.ComponentModel.Browsable(false)]
public virtual System.Web.UI.WebControls.DataKeyArray DataKeys { get; }
[<System.ComponentModel.Browsable(false)>]
member this.DataKeys : System.Web.UI.WebControls.DataKeyArray
Public Overridable ReadOnly Property DataKeys As DataKeyArray

Valor de Propriedade

Um objeto que contém a chave de dados para cada item num ListView controlo.

Atributos

Exemplos

O exemplo seguinte mostra como usar a DataKeys propriedade para determinar os valores da chave de dados para os itens num ListView controlo. Também mostra como preservar a seleção do utilizador baseada num elemento de dados em vez do comportamento padrão que usa o índice.

void ContactsListView_SelectedIndexChanged(Object sender, EventArgs e)
{
  if (ContactsListView.SelectedIndex >= 0)
    ViewState["SelectedKey"] = ContactsListView.SelectedValue;
  else
    ViewState["SelectedKey"] = null;
}

void ContactsListView_DataBound(Object sender, EventArgs e)
{
  for (int i = 0; i < ContactsListView.Items.Count; i++)
  {
    // Ignore values that cannot be cast as integer.
    try
    {
        if ((int)ContactsListView.DataKeys[i].Value == (int)ViewState["SelectedKey"])
            ContactsListView.SelectedIndex = i;
    }
    catch { }
  }
}
Sub ContactsListView_SelectedIndexChanged(ByVal sender As Object, ByVal e As EventArgs)
  If ContactsListView.SelectedIndex >= 0 Then
    ViewState("SelectedKey") = ContactsListView.SelectedValue
  Else
    ViewState("SelectedKey") = Nothing
  End If
End Sub

Sub ContactsListView_DataBound(ByVal sender As Object, ByVal e As EventArgs)
  For i As Integer = 0 To ContactsListView.Items.Count - 1
    ' Ignore values that cannot be cast as integer.
    Try
      If Convert.ToInt32(ContactsListView.DataKeys(i).Value) = Convert.ToInt32(ViewState("SelectedKey")) Then _
        ContactsListView.SelectedIndex = i
    Catch
    End Try
  Next
End Sub

Observações

Quando a DataKeyNames propriedade é definida, o controlo ListView cria automaticamente um DataKey objeto para cada item do controlo. O DataKey objeto contém os valores do campo ou campos especificados na DataKeyNames propriedade. Os DataKey objetos são então adicionados à coleção do DataKeys controlo.

Use a DataKeys propriedade para recuperar o DataKey objeto de um elemento de dados específico no ListView controlo.

Podes usar a SelectedDataKey propriedade para recuperar o DataKey objeto do item atualmente selecionado. Também pode usar a SelectedValue propriedade para recuperar diretamente o valor da chave de dados do item atualmente selecionado.

Pode usar a ListViewDataItem.DisplayIndex propriedade para recuperar o DataKey objeto do item para o qual foi clicado um botão de comando.

Aplica-se a

Ver também